/////////////////////////////////////////////////////////////////////////////// | |
// // | |
// Copyright (c) 2000-2019 Ericsson Telecom AB // | |
// // | |
// All rights reserved. This program and the accompanying materials // | |
// are made available under the terms of the Eclipse Public License v2.0 // | |
// which accompanies this distribution, and is available at // | |
// https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.html // | |
/////////////////////////////////////////////////////////////////////////////// | |
/////////////////////////////////////////////////////////// | |
// Module: EPTF_CLL_UIHandler_WidgetFunctions | |
// | |
// Purpose: | |
// This module contains widget manipulation functions of EPTF_UIHandler_CT. | |
// | |
// Module Parameters: | |
// charstring tsp_EPTF_GUI_Main_Window_WidgetId := "EPTF_Main_Window"; used in | |
// <f_EPTF_UIHandler_addWindow> creating a new window | |
// charstring tsp_EPTF_GUI_Main_Toolbar_WidgetId := "EPTF_Main_Toolbar"; | |
// float tsp_EPTF_GUI_Main_Window_Width := 820.0; used in | |
// <f_EPTF_UIHandler_addWindow> creating a new window | |
// float tsp_EPTF_GUI_Main_Window_Height := 386.0; used in | |
// <f_EPTF_UIHandler_addWindow> creating a new window | |
// charstring tsp_EPTF_GUI_Main_Window_Title := "TTCN constructed window"; used in | |
// <f_EPTF_UIHandler_addWindow> creating a new window | |
// charstring tsp_xtdp_listen_addr := "127.0.0.1"; | |
// integer tsp_xtdp_listen_port := 11420; | |
// charstring tsp_EPTF_savedGUIPrefix := "GUI"; used to create a snapshot | |
// config file about the GUI | |
// charstring tsp_EPTF_GUI_DefaultWindow := ""; If it isn't empty, the | |
// EPTF_UIHandler_CT tries to create a window by this string. It | |
// can be created by the <f_EPTF_UIHandler_snapshot> and | |
// <f_EPTF_UIHandler_saveLayout> functions. | |
// charstring tsp_EPTF_UIHandler_Authmsg := "Enter password" This is the question | |
// for XTDP authentication that the user of the RuntimeGUI has to answer. | |
// If it is empty, no authentication performed | |
// charstring tsp_EPTF_UIHandler_Authresp := ""; This is the expected | |
// answer for the question <tsp_EPTF_UIHandler_Authmsg> during XTDP | |
// authentication. If the answer given on RuntimeGUI does not match this | |
// parameter, the authentication fails and XTDP session will be closed. | |
// UIHander will enter into headless mode. | |
// If it is empty, no authentication performed | |
// float tsp_EPTF_UIHandler_handshakeMaxTimer := 1.0; This is the max handshake | |
// time for the XDTP protocol. The handshake response should arrive less than | |
// this time. (See the XTDP protocol module FS for more details) | |
// float tsp_EPTF_UIHandler_authMaxTimer := 1.0; This is the max authentication time. | |
// for the XDTP protocol. The authentication response should arrive less than | |
// this time. (See the XTDP protocol module FS for more details) | |
// float tsp_EPTF_UIHandler_byeMaxTimer := 1.0; This is the max bye time. | |
// for the XDTP protocol. The bye response should arrive less than | |
// this time. (See the XTDP protocol module FS for more details) | |
// float tsp_EPTF_UIHandler_maxGUIWaitTime := 30.0; The max wait time in the | |
// init function of the UIhandler (<f_EPTF_UIHandler_init_CT>) to wait | |
// until Runtime GUI is connected. | |
// | |
// Module depends on: | |
// <XTDPasp_Types> | |
// <XTDP_PDU_Defs> | |
// <XUL_XTDL language> | |
// <EPTF_CLL_UIHandler_MsgDefinitions> | |
// <EPTF_CLL_UIHandler_Definitions> | |
// <EPTF_CLL_UIHandler_PrivateFunctions> | |
// <EPTF_CLL_Base_Definitions> | |
// <EPTF_CLL_Base_Functions> | |
// <EPTF_CLL_UIHandler_XTDPTemplateDefinitions> | |
// <EPTF_CLL_Variable_Definitions> | |
// <EPTF_CLL_Variable_Functions> | |
// <EPTF_CLL_UIHandler_ConvertFunctions> | |
// <EPTF_CLL_Common_Definitions> | |
// <EPTF_CLL_HashMapStr2Int_Functions> | |
// <EPTF_CLL_HashMapInt2Int_Functions> | |
// <EPTF_CLL_Logging_Definitions> | |
// <EPTF_CLL_Logging_Functions> | |
// <TCCFileIO_Functions> | |
// <TCCDateTime_Functions> | |
// <EPTF_CLL_TransportIPL4_Functions> | |
// <EPTF_CLL_Transport_CommonDefinitions> | |
// <EPTF_CLL_Semaphore_Functions> | |
// <EPTF_CLL_UIHandler_CLIClientDefinitions> | |
// <EPTF_CLL_UIHandlerCLI_CommandDefinitions> | |
// <EPTF_CLL_CLI_Functions> | |
// <EPTF_CLL_CLI_Definitions> | |
// <Socket_API_Definitions> | |
// <EPTF_CLL_HashMap_Functions> | |
// | |
// Current Owner: | |
// EFLOATT | |
// | |
// Last Review Date: | |
// 2010-xx-xx | |
// | |
// Detailed Comments: | |
// - | |
// | |
/////////////////////////////////////////////////////////////// | |
module EPTF_CLL_UIHandler_WidgetFunctions | |
// [.objid{ itu_t(0) identified_organization(4) etsi(0) | |
// identified_organization(127) ericsson(5) testing(0) | |
// <put further nodes here if needed>}] | |
{ | |
//========================================================================= | |
// Import Part | |
//========================================================================= | |
import from EPTF_CLL_UIHandler_MsgDefinitions all; | |
import from EPTF_CLL_UIHandler_Definitions all; | |
import from EPTF_CLL_Base_Functions all; | |
import from EPTF_CLL_UIHandler_XSD_XTDPTemplateDefinitions all; | |
import from EPTF_CLL_Variable_Definitions all; | |
import from EPTF_CLL_Variable_Functions all; | |
import from EPTF_CLL_UIHandler_ConvertFunctions all; | |
import from EPTF_CLL_Common_Definitions all; | |
import from EPTF_CLL_Common_Functions all; | |
import from EPTF_CLL_HashMapStr2Int_Functions all; | |
import from EPTF_CLL_HashMapInt2Int_Functions all; | |
import from EPTF_CLL_Logging_Definitions all; | |
import from EPTF_CLL_Logging_Functions all; | |
import from TCCFileIO_Functions all; | |
import from TCCDateTime_Functions all; | |
import from TCCConversion_Functions all; | |
import from EPTF_CLL_TransportIPL4_Functions all; | |
import from EPTF_CLL_Transport_CommonDefinitions all; | |
import from EPTF_CLL_TransportMessageBufferManager_Functions all; | |
import from EPTF_CLL_Semaphore_Functions all; | |
import from EPTF_CLL_UIHandler_CLIClientDefinitions all; | |
import from EPTF_CLL_CLI_Functions all; | |
import from EPTF_CLL_CLI_Definitions all; | |
import from Socket_API_Definitions all | |
import from XTDP_EncDecFunctions all; | |
import from ttcn_ericsson_se_protocolModules_xtdp_xtdl all; | |
import from ttcn_ericsson_se_protocolModules_xtdp_xtdp all; | |
import from EPTF_CLL_DataSource_Definitions all; | |
import from EPTF_CLL_DataSource_Functions all; | |
import from EPTF_CLL_UIHandler_DS_Definitions all; | |
import from EPTF_CLL_UIHandler_DS_Functions all; | |
import from EPTF_CLL_DataSourceClient_Functions all; | |
import from EPTF_CLL_HashMap_Functions all; | |
import from EPTF_CLL_StatManager_Functions all; | |
import from EPTF_CLL_UIHandler_BrowserFunctions all; | |
import from EPTF_CLL_UIHandler_ChartDataTypeRingBuffer_Functions all; | |
//========================================================================= | |
// Module Parameters | |
//========================================================================= | |
modulepar { | |
charstring tsp_EPTF_GUI_Main_Window_WidgetId := "EPTF_Main_Window"; | |
charstring tsp_EPTF_GUI_Main_Toolbar_WidgetId := "EPTF_Main_Toolbar"; | |
charstring tsp_EPTF_GUI_Main_Tabbox_WidgetId := "EPTF_Main_Tabbox"; | |
float tsp_EPTF_GUI_Main_Window_Width := 820.0; | |
float tsp_EPTF_GUI_Main_Window_Height := 386.0; | |
charstring tsp_EPTF_GUI_Main_Window_Title := "TTCN constructed window"; | |
charstring tsp_xtdp_listen_addr := "127.0.0.1"; | |
integer tsp_xtdp_listen_port := 11420; | |
integer tsp_EPTF_UIHandler_udp_port := 3333; // remote port number for pinger port | |
charstring tsp_EPTF_UIHandler_localPingerAddr := c_ipv4AnyAddr; | |
integer tsp_EPTF_UIHandler_localPingerPort := c_anyPort; // 0-> let the kernel choose a local port number automatically | |
charstring tsp_EPTF_savedGUIPrefix := "GUI"; | |
charstring tsp_EPTF_GUI_DefaultWindow := ""; // OUTDATED, remove it from any config | |
charstring tsp_EPTF_GUI_DefaultWindowXTDL := ""; | |
boolean tsp_EPTF_UIHandler_headlessmode := true; | |
boolean tsp_EPTF_UIHandler_servermode := false; | |
charstring tsp_EPTF_UIHandler_Authmsg := "Enter password"; | |
charstring tsp_EPTF_UIHandler_Authresp := ""; | |
float tsp_EPTF_UIHandler_handshakeMaxTimer := 1.0; | |
float tsp_EPTF_UIHandler_authMaxTimer := 1.0; | |
float tsp_EPTF_UIHandler_byeMaxTimer := 1.0; | |
float tsp_EPTF_UIHandler_bufferedXTDP := 0.5; | |
float tsp_EPTF_UIHandler_connecttimer := 5.0; | |
float tsp_EPTF_UIHandler_maxWaitTimer := 5.0; | |
integer tsp_EPTF_UIHandler_CommPortIPL4_minBufferSize := 2000; | |
boolean tsp_debug_EPTF_UIHandler_Functions := false; | |
float tsp_EPTF_UIHandler_maxGUIWaitTime := 30.0; | |
boolean tsp_EPTF_UIHandler_enableBrowserGUI := true; | |
EPTF_Var_SubscriptionMode tsp_EPTF_UIHandler_subscriptionMode := sampled; // sampled is the default for tsp_EPTF_DataSource_subscriptionMode, with pull widgets on RuntimeGUI do not update | |
} | |
friend module EPTF_CLL_UIHandlerVariableUI_Functions, EPTF_CLL_UIHandlerCLI_Functions,EPTF_CLL_UIHandler_XULFunctions; | |
friend module EPTF_UIHandler_Test_Testcases, EPTF_CLL_UIHandler_BrowserFunctions; | |
friend module EPTF_UIHandler_Test_Functions; | |
const charstring cg_ExternalVariableSign := "__ExternalValue"; | |
//========================================================================= | |
// Public functions | |
//========================================================================= | |
group PublicFunctions { | |
public external function f_EPTF_UIHandler_init_XML(); | |
public external function f_EPTF_UIHandler_cleanup_XML(); | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_init_CT | |
// | |
// Purpose: | |
// Initialises the EPTF_UIHandler_CT | |
// | |
// Parameters: | |
// pl_selfName - *in* *charstring* - the name used in the initialization | |
// of the f_EPTF_Base_CT | |
// pl_CLI_compRef - *in* <EPTF_CLI_CT> - the CLI to use. | |
// Default: null (== local CLI ports are disabled) | |
// pl_connectGUI - *in* *boolean* - default: true. If it is true | |
// UIHandler will try to connect to the RuntimeGUI and will perform | |
// the XTDP handshake and authentication. The init function will | |
// exit after the XTDP session is connected. If the transport connection | |
// failed but the headless mode is true, the init function will exit | |
// with XTDP session not established and the UIHandler will enter | |
// into headless mode. | |
// pl_windowLayout - *in template* *charstring* - This parameter defines the initial | |
// gui layout in xml format. Must fit the XTDL.xsd. If it is omit (default value), | |
// UIHandler gets the <tsp_EPTF_GUI_DefaultWindowXTDL> module parameter, which can | |
// describe the GUI true. If it contains an empty string, there is no initial GUI. | |
// pl_prefix - *in* *charstring* - (default:tsp_EPTF_UIHandler_CLIPrefix) - | |
// common prefix for the UIHandler Command-Line Interface commands | |
// pl_simulationMode - *in* *boolean* - (default:false) - | |
// If this parameter is true, UIHandler will be initialized in simulation mode | |
// pl_simulation_buildDB_file - *in* *charstring* - (default:"") - | |
// The parameter is definies the file, what will be used to save the database | |
// or load the database in simulation mode | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// Error occurs in client mode (i.e. if tsp_EPTF_UIHandler_servermode is false) | |
// if | |
// - pl_connectGUI true, headless mode is false, and it is not possible | |
// to connect to the RuntimeGUI. | |
// - pl_connectGUI false and headless mode is false | |
// - pl_connectGUI true but XTDP handshake&authentication is not | |
// performed in time (during tsp_EPTF_UIHandler_maxGUIWaitTime seconds) | |
// | |
// Detailed Comments: | |
// This function should be called before using the EPTF_UIHandler_CT | |
// component. | |
// Currently simulation mode is not supported, so do not change the values of | |
// the following parameters: | |
// pl_simulationMode | |
// pl_simulation_buildDB_file | |
// To get it (simulation mode) working nonblocking version of the f_EPTF_UIHandler_simulation_getData | |
// function needs to be implemented. | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_init_CT( | |
in charstring pl_selfName, | |
in boolean pl_connectGUI := true, | |
in template charstring pl_windowLayout := "", | |
in EPTF_CLI_CT pl_CLI_compRef := null, | |
in charstring pl_prefix := tsp_EPTF_UIHandler_CLIPrefix, | |
in boolean pl_simulationMode := false, | |
in charstring pl_simulation_buildDB_file := "", | |
in boolean pl_headlessmode := tsp_EPTF_UIHandler_headlessmode, | |
in boolean pl_servermode := tsp_EPTF_UIHandler_servermode, | |
in charstring pl_authresp := tsp_EPTF_UIHandler_Authresp ) | |
runs on EPTF_UIHandler_Private_CT { | |
if (not v_UIHandler_initialized) { | |
v_EPTF_UIHandler_simulatonMode := pl_simulationMode; | |
v_EPTF_UIHandler_simulation_buildDB_file := pl_simulation_buildDB_file; | |
v_UIHandler_simulation_directContentDB := {}; | |
if(isvalue(pl_windowLayout)){ | |
v_UIHandler_windowLayout := valueof(pl_windowLayout); | |
v_UIHandler_emptyGUI := false; | |
}else{ | |
v_UIHandler_windowLayout := ""; | |
v_UIHandler_emptyGUI := true; | |
} | |
v_EPTF_UIHandler_createLayoutCallback := refers(f_EPTF_UIHandler_newCreateInitialLayout); | |
f_EPTF_UIHandler_init_XML(); | |
f_EPTF_UIHandler_initComponent(pl_selfName, pl_CLI_compRef, pl_prefix, pl_headlessmode, pl_servermode, pl_authresp); | |
f_EPTF_UIHandler_connect(pl_connectGUI); | |
f_EPTF_UIHandler_simulation_Subscribe2saveDBButton_vars(); | |
if(v_EPTF_UIHandler_simulatonMode == true) { | |
f_EPTF_UIHandler_simulation_createDBFromFile(pl_simulation_buildDB_file, v_UIHandler_simulation_directContentDB); | |
var integer vl_directContentDBSize := sizeof(v_UIHandler_simulation_directContentDB); | |
for(var integer vl_i := 0; vl_i < vl_directContentDBSize; vl_i := vl_i + 1) { | |
f_EPTF_str2int_HashMap_Insert(v_UIHandler_simulation_varsHashMapId, v_UIHandler_simulation_directContentDB[vl_i].key, vl_i); | |
f_EPTF_Var_newVar(v_UIHandler_simulation_directContentDB[vl_i].key, v_UIHandler_simulation_directContentDB[vl_i].directContent) | |
} | |
} | |
v_EPTF_UIHandler_WidgetFunctions_XTDP_XSD_filepath := ""; | |
} | |
} | |
friend function f_EPTF_UIHandler_initComponent( | |
in charstring pl_selfName, | |
in EPTF_CLI_CT pl_CLI_compRef := null, | |
in charstring pl_prefix := tsp_EPTF_UIHandler_CLIPrefix, | |
in boolean pl_headlessmode := tsp_EPTF_UIHandler_headlessmode, | |
in boolean pl_servermode := tsp_EPTF_UIHandler_servermode, | |
in charstring pl_authresp := tsp_EPTF_UIHandler_Authresp) | |
runs on EPTF_UIHandler_Private_CT { | |
v_EPTF_UIHandler_headlessmode := pl_headlessmode; | |
v_EPTF_UIHandler_servermode := pl_servermode; | |
v_EPTF_UIHandler_Authresp := pl_authresp; | |
v_UIHandler_initToGUIClient := false; | |
v_UIHandler_createGUIRunning := false; | |
t_UIHandler_initGUIToClientTimer.start; | |
v_UIHandler_cleanupCalled := false; | |
v_UIHandler_openSubscriptions := {}; | |
v_UIHandler_subscriptions := {}; | |
v_UIHandler_guiLayoutReady := false; | |
v_UIHandler_guiItemList := {}; | |
v_UIHandler_tracePointers := {}; | |
v_UIHandler_windowIndex := -1; | |
//KI - 2013.11.04. - ez kimehetne, most kikotom a hasznalatat | |
v_UIHandler_GUI_DescriptionDB := {}; | |
v_UIHandler_GUI_DescriptionDB_Idx := -1; | |
v_UIHandler_nofRunning_processExternalData_handlers := 0; | |
v_UIHandler_GUIFunctions_nofRunning_processExternalData_handlers := {}; // used to wait for all EPTF_CLL_UIHandler_GUIFunctions.cc[expand_current_node] functions to finish | |
f_EPTF_HashMap_init_CT (pl_selfName); | |
v_EPTF_UIHandler_Config_ConnectVarToWidgets := {}; | |
v_handshakeMaxTime := tsp_EPTF_UIHandler_handshakeMaxTimer; | |
v_handshakeErrorMsg := ""; | |
v_authMaxTime := tsp_EPTF_UIHandler_authMaxTimer; | |
v_byeMaxTime := tsp_EPTF_UIHandler_byeMaxTimer; | |
v_UIHandler_byeTimer := -1; | |
f_EPTF_Var_init_CT(pl_selfName); | |
f_EPTF_Logging_init_CT(pl_selfName); | |
f_EPTF_DataSource_init_CT(pl_selfName); | |
f_EPTF_StatManager_init_CT(pl_selfName); | |
if(self == pl_CLI_compRef) { | |
// if I am the CLI: initialize it (with telnet ports enabled): | |
f_EPTF_CLI_init_CT(pl_selfName) | |
} else { | |
// if remote or null CLI is used, disable all telnet ports in the CLI: | |
f_EPTF_CLI_init_CT(pl_selfName,*,*); | |
} | |
// NOTE: | |
// If pl_CLI_compRef is null: the CLI client will be initialized with self as CLI | |
// and the commands will be registered also. | |
// This is because if f_EPTF_UIHandler_CLI_init_CT is called later, | |
// that will enable the telnet ports, so the commands should be there. | |
if(null == pl_CLI_compRef){pl_CLI_compRef := self} | |
f_EPTF_CLI_Client_init_CT(pl_selfName, pl_CLI_compRef) | |
f_EPTF_UIHandler_CLIClient_init_CT(pl_prefix); | |
f_EPTF_DataSource_CLI_init_CT(pl_selfName, pl_CLI_compRef); | |
v_UIHandler_loggingMaskId := f_EPTF_Logging_registerComponentMasks(tsp_EPTF_UIHandler_loggingComponentMask, c_EPTF_UIHandler_loggingEventClasses, EPTF_Logging_CLL); | |
if(tsp_debug_EPTF_UIHandler_Functions) { | |
f_EPTF_Logging_enableLocalMask(v_UIHandler_loggingMaskId, c_EPTF_UIHandler_loggingClassIdx_Debug); | |
} else { | |
f_EPTF_Logging_disableLocalMask(v_UIHandler_loggingMaskId, c_EPTF_UIHandler_loggingClassIdx_Debug); | |
} | |
v_UIHandler_widgetHashMapId := f_EPTF_str2int_HashMap_New(c_EPTF_UIHandler_widgetIdHashMapName); | |
v_UIHandler_tracePointerHashMapId := f_EPTF_int2int_HashMap_New(c_EPTF_UIHandler_tracePointerHashMapName); | |
v_UIHandler_subscriptionHashMapId := f_EPTF_str2int_HashMap_New(c_EPTF_UIHandler_subscriptionHashMapName); | |
v_UIHandler_subscriptionHashMapIdVar := f_EPTF_str2int_HashMap_New(c_EPTF_UIHandler_subscriptionHashMapNameVar); | |
v_UIHandler_simulation_varsHashMapId := f_EPTF_str2int_HashMap_New(c_EPTF_UIHandler_simulation_varsHashMapName); | |
f_EPTF_Semaphore_init_CT(pl_selfName); | |
v_UIHandler_xtdpReceivedMessageSemaphore_r := f_EPTF_Semaphore_new(); | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
v_UIHandler_layoutResponseReceivedSemaphore := f_EPTF_Semaphore_new(); | |
v_UIHandler_exitButtonPressedSemaphore := f_EPTF_Semaphore_new(); | |
v_UIHandler_progressEnabled := true; | |
f_EPTF_UIHandler_initProgressBar(); | |
f_EPTF_Transport_init(IPL4, pl_selfName) | |
//FIXME use the new API | |
f_EPTF_Transport_registerMsgLenCallback4LGenType(IPL4, refers(f_EPTF_UIHandler_getMsgLen_XTDP), {}, c_EPTF_UIHandler_XTDPType); | |
f_EPTF_Transport_registerMsgCallback(IPL4, c_EPTF_UIHandler_XTDPType, refers(f_EPTF_UIHandler_HandleMsgs_XTDP), refers(f_EPTF_UIHandler_HandleEvent_XTDP)); | |
f_EPTF_MessageBufferManager_MaxBufferSize_setMinValue(tsp_EPTF_UIHandler_CommPortIPL4_minBufferSize); | |
f_EPTF_Base_registerCleanup(refers(f_EPTF_UIHandler_cleanup_CT)); | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug("----EPTF_UIHandler 0.8610 INIT DONE----"); | |
} | |
f_EPTF_DataSourceClient_init_CT(f_EPTF_Base_selfName(), self); | |
f_EPTF_DataSourceClient_registerData(c_UIHandler_DS_sourceId, f_EPTF_Base_selfName(), refers(f_EPTF_UIhandler_DSProcessData), self); | |
f_EPTF_DataSourceClient_registerDataValue(c_UIHandler_DS_sourceId, f_EPTF_Base_selfName(), refers(f_EPTF_UIHandler_DSProcessDataValue), self); | |
f_EPTF_DataSourceClient_sendReady(c_UIHandler_DS_sourceId, f_EPTF_Base_selfName()); | |
if(tsp_EPTF_UIHandler_enableBrowserGUI){ | |
f_EPTF_UIHandler_Browser_init_CT( ); | |
} | |
v_EPTF_UIHandler_Traces_HashmapId := f_EPTF_str2int_HashMap_New("TracesHashMap"); | |
v_UIHandler_initialized := true; | |
if(f_EPTF_UIHandler_layoutReady()) { | |
//f_EPTF_UIHandler_createInitialLayout(pl_windowLayout); // initial window is created in internal DB before trying to connect to GUI | |
if(null != v_EPTF_UIHandler_createLayoutCallback){ | |
v_EPTF_UIHandler_createLayoutCallback.apply(); | |
} | |
} | |
f_EPTF_UIHandler_updateOwnProgress("Initializing: Done."); | |
f_EPTF_Base_waitForCondition(refers(f_EPTF_UIHandler_checkDataSourceReady)) | |
} | |
private function f_EPTF_UIHandler_checkDataSourceReady() | |
runs on EPTF_UIHandler_Private_CT return boolean{ | |
var charstring vl_varName := ""; | |
var integer vl_returnVal := f_EPTF_DataSource_checkData( | |
pl_dataVarName := vl_varName, | |
pl_source := c_UIHandler_DS_sourceId, | |
pl_ptcName := "", | |
pl_element := c_UIHandler_dataElement_progressBar, | |
pl_params := {}); | |
return vl_returnVal == 0; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_updateProgress | |
// | |
// Purpose: | |
// Update the value of the dataSource containing the progress information | |
// | |
// Parameters: | |
// pl_progressInfo - *in* *charstring* - the new progress information to show | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// - | |
// | |
// Detailed Comments: | |
// The progress history is updated automatically | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_updateProgress(in charstring pl_progressInfo, in float vl_progressPercent := -1.0) runs on EPTF_UIHandler_Private_CT { | |
if (not v_UIHandler_initialized){ return } | |
var charstring vl_progressPercentStr := ""; | |
if (vl_progressPercent>=0.0) { | |
vl_progressPercentStr := ": "&int2str(float2int(vl_progressPercent))&"%"; | |
} | |
f_EPTF_Var_adjustContent(f_EPTF_Var_getId(c_UIHandler_DS_var_prefix&c_UIHandler_dataElement_progressBar),{charstringVal := pl_progressInfo&vl_progressPercentStr}); | |
} | |
private function f_EPTF_UIHandler_initProgressBar() runs on EPTF_UIHandler_Private_CT { | |
// create progress bar variable: | |
var integer vl_progressBar_Idx, vl_progressBarHistory_Idx; | |
f_EPTF_Var_newCharstring(c_UIHandler_DS_var_prefix&c_UIHandler_dataElement_progressBar,"",vl_progressBar_Idx); | |
f_EPTF_Var_newCharstring(c_UIHandler_DS_var_prefix&c_UIHandler_dataElement_progressBarHistory,"",vl_progressBarHistory_Idx); | |
f_EPTF_Var_addPostProcFn(vl_progressBar_Idx,{ | |
refers(f_EPTF_UIHandler_progressBarHistory_PostProc), | |
{vl_progressBarHistory_Idx} | |
}); | |
f_EPTF_Var_setSubsCanAdjust(vl_progressBarHistory_Idx,false); | |
f_EPTF_UIHandler_updateOwnProgress("Initializing..."); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_enableOwnProgress | |
// | |
// Purpose: | |
// Enables UIHandler's own progress information updates | |
// | |
// Parameters: | |
// pl_enableOwnProgress - *in* *boolean* - true: enable, false: disable | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// - | |
// | |
// Detailed Comments: | |
// - | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_enableOwnProgress(in boolean pl_enableOwnProgress) runs on EPTF_UIHandler_Private_CT { | |
v_UIHandler_progressEnabled := pl_enableOwnProgress; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_updateOwnProgress | |
// | |
// Purpose: | |
// Update the value of the dataSource containing the progress information with the UIHandler's own progress info | |
// | |
// Parameters: | |
// pl_progressInfo - *in* *charstring* - the new progress information to show | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// - | |
// | |
// Detailed Comments: | |
// The progress history is updated automatically | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_updateOwnProgress(in charstring pl_progressInfo, in float vl_progressPercent := -1.0) runs on EPTF_UIHandler_Private_CT { | |
if (v_UIHandler_progressEnabled) { | |
f_EPTF_UIHandler_updateProgress(c_UIHandler_DS_sourceId&": "&pl_progressInfo,vl_progressPercent); | |
} | |
} | |
// appends the progressBar var content to the progressBarHistory var: | |
private function f_EPTF_UIHandler_progressBarHistory_PostProc(in integer pl_idx, in EPTF_IntegerList pl_argList) runs on EPTF_UIHandler_Private_CT { | |
// content of the progressBar var: | |
var integer vl_progressBarHistory_Idx := pl_argList[0]; | |
f_EPTF_Var_adjustContent( | |
vl_progressBarHistory_Idx, | |
{ | |
charstringVal := f_EPTF_Var_getCharstringValue(vl_progressBarHistory_Idx)&"\n"&f_EPTF_Var_getCharstringValue(pl_idx) | |
} | |
); | |
} | |
friend function f_EPTF_UIHandler_connect(in boolean pl_connectGUI) | |
runs on EPTF_UIHandler_Private_CT { | |
var ConnectionId vl_connId := -1; | |
var boolean vl_UIHandler_transportConnectionFailed := false; | |
if (v_EPTF_UIHandler_servermode){ | |
// server mode | |
f_EPTF_UIHandler_headlessmode(); | |
} else { | |
// client mode | |
f_EPTF_Transport_registerMsgCallback(IPL4, c_EPTF_UIHandler_pingerTransport, refers(f_EPTF_UIHandler_pingerReceive)); | |
var Result vl_result | |
f_EPTF_Transport_listen(IPL4, { udp := {} }, tsp_EPTF_UIHandler_localPingerAddr, tsp_EPTF_UIHandler_localPingerPort, c_EPTF_UIHandler_pingerTransport, vl_result, false) | |
if (ispresent(vl_result.errorCode) and (vl_result.errorCode != ERROR_TEMPORARILY_UNAVAILABLE)) { | |
f_EPTF_UIHandler_error("Could not open pinger port: " & log2str(vl_result)); | |
} | |
v_UIHandler_pingerConnectionId := vl_result.connId; | |
v_UIHandler_udp_port := tsp_EPTF_UIHandler_udp_port; | |
// Checks for GUI address that is set by the user. | |
// If not use the address from module parameter. | |
if (v_UIHandler_GUI_Host == c_EPTF_UIHandler_Invalid_GUI_Host or | |
v_UIHandler_GUI_Port == c_EPTF_UIHandler_Invalid_GUI_Port) { | |
v_UIHandler_GUI_Host := tsp_xtdp_listen_addr; | |
v_UIHandler_GUI_Port := tsp_xtdp_listen_port; | |
} | |
if(pl_connectGUI){ | |
// try to connect to GUI | |
var EPTF_UIHandler_connectionResult vl_res := f_EPTF_UIHandler_connectAndInitGui(vl_connId); | |
if(connected != vl_res){ | |
if (v_EPTF_UIHandler_headlessmode) { | |
// connect to GUI failed -> switch to headless mode | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug("initGUI failed, switch to headless mode"); | |
} | |
f_EPTF_UIHandler_headlessmode(); | |
vl_UIHandler_transportConnectionFailed := vl_res != temporarilyUnavailable; | |
} else { | |
// connecting to GUI failed and headless mode not enabled -> stop running | |
f_EPTF_UIHandler_error("initGUI failed!"); | |
} | |
} | |
} else if (v_EPTF_UIHandler_headlessmode) { | |
// headless mode enabled -> switch to headless mode | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug("UIHandler started in headless mode"); | |
} | |
f_EPTF_UIHandler_headlessmode(); | |
} else { | |
// uncorrect starrtup configuration: client mode, not to connect to GUI, headless mode disabled -> stop running | |
f_EPTF_UIHandler_error("Uncorrect UIHandler configuration for startup: client mode, not to connect to GUI, headless mode disabled"); | |
} | |
} | |
if (tsp_EPTF_UIHandler_bufferedXTDP != 0.0){ | |
//v_UIHandler_Requestbuffer.data.noNamespaceSchemaLocation := omit; | |
v_UIHandler_Requestbuffer.data.transactionID := omit; | |
v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.ackRequested := omit; | |
f_EPTF_UIHandler_requestBuffer_clear(); | |
t_UIHandler_bufferedXTDP.start(tsp_EPTF_UIHandler_bufferedXTDP); | |
} | |
v_UIHandler_def := activate(as_handle_main_EPTF_UIHandler_MgmtIf()); | |
// wait for gui connect (handshake and authentication) if transport is already connected | |
if ((pl_connectGUI and not v_EPTF_UIHandler_servermode) and not vl_UIHandler_transportConnectionFailed) { | |
timer t_wait_for_connectGUI := 0.0; | |
timer t_max_wait_for_connectGUI := tsp_EPTF_UIHandler_maxGUIWaitTime; | |
t_max_wait_for_connectGUI.start; | |
t_wait_for_connectGUI.start; | |
alt { | |
[v_UIHandler_guiConnected or (vl_connId != -1 and not f_EPTF_UIHandler_isConnectedClientid(vl_connId))] t_wait_for_connectGUI.timeout { | |
// connection established, or lost | |
} | |
[] t_max_wait_for_connectGUI.timeout { | |
// bugfix_HR17649 - error => warning | |
f_EPTF_UIHandler_warning("In client mode connecting to the RuntimeGUI on " & v_UIHandler_GUI_Host & ":" & log2str(v_UIHandler_GUI_Port) & " failed: Timeout during handshake&authentication. RuntimeGUI is not responding. Please correct the tsp_xtdp_listen_addr / tsp_xtdp_listen_port parameter(s) or restart the RuntimeGUI! "); | |
f_EPTF_UIHandler_headlessmode(); | |
} | |
} | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_newCreateInitialLayout | |
// | |
// Purpose: | |
// Create initial layout based on settings | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_newCreateInitialLayout() | |
runs on EPTF_UIHandler_Private_CT | |
{ | |
var boolean vl_ret := false; | |
if(not v_UIHandler_emptyGUI){ | |
// If no window is given neither from parameter nor from tsp, parameter is not given, or contains the default value -> | |
// create a simple window and a main tabbox | |
// This is the backward compatible way | |
if("" == v_UIHandler_windowLayout and "" == tsp_EPTF_GUI_DefaultWindow){ | |
// no window is given -> create a simple window and a main tabbox | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": Creating a window and a main tabbox"); | |
} | |
vl_ret := f_EPTF_UIHandler_addWindow(); | |
vl_ret := vl_ret and f_EPTF_UIHandler_addMainTabbox(); | |
} | |
else { | |
if ("" != v_UIHandler_windowLayout) { | |
// create window given in parameter | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": Creating window specified by function parameter: "&log2str(v_UIHandler_windowLayout)); | |
} | |
f_EPTF_UIHandler_createGUIFromWindow(v_UIHandler_windowLayout); | |
//vl_wndXul := f_EPTF_UIHandler_XSD_decodeXUL(pl_windowLayout); | |
} | |
else if ("" != tsp_EPTF_GUI_DefaultWindow) { | |
// create window from specified in tsp | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": Creating window specified by tsp_EPTF_GUI_DefaultWindowXTDL: "&log2str(tsp_EPTF_GUI_DefaultWindowXTDL)); | |
} | |
f_EPTF_UIHandler_createGUIFromWindow(tsp_EPTF_GUI_DefaultWindowXTDL); | |
//vl_wndXul := f_EPTF_UIHandler_XSD_decodeXUL(tsp_EPTF_GUI_DefaultWindow); | |
} | |
if (not vl_ret) { | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&" failed, could not create initial GUI"); | |
} | |
} | |
} | |
} | |
} | |
private function f_EPTF_UIHandler_createGUIFromWindow(in charstring pl_window) | |
runs on EPTF_UIHandler_Private_CT{ | |
var Widgets vl_widgets := f_EPTF_UIHandler_XSD_decodeXUL(pl_window); | |
if(not ischosen(vl_widgets.window)){ | |
f_EPTF_UIHandler_error(%definitionId&": The received XUL is invalid, not window or it can not be decoded fully.\n"& | |
"For further detailes see the log file above.") | |
} | |
f_EPTF_UIHandler_createGUI(pl_window); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_cleanup_CT | |
// | |
// Purpose: | |
// Destructs the EPTF_UIHandler_CT | |
// | |
// Parameters: | |
// - | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// none | |
// | |
// Detailed Comments: | |
// This function mustn't be called directly. You must call f_EPTF_Base_cleanup_CT instead. | |
/// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_cleanup_CT() runs on EPTF_UIHandler_Private_CT { | |
// f_EPTF_Logging_debug(true, "v_UIHandler_initialized: "& v_UIHandler_initialized &" v_UIHandler_guiConnected: "& v_UIHandler_guiConnected); | |
if (v_UIHandler_initialized) | |
{ | |
v_UIHandler_cleanupCalled := true; | |
if(t_UIHandler_pingtimer.running) { | |
t_UIHandler_pingtimer.stop; | |
} | |
if(t_UIHandler_initGUIToClientTimer.running) { | |
t_UIHandler_initGUIToClientTimer.stop; | |
} | |
if(v_UIHandler_guiConnected) | |
{ | |
for (var integer i := 0; i<sizeof(v_UIHandler_GUIClientId); i:= i+1) | |
{ | |
f_EPTF_UIHandler_closeXTDPSession(v_UIHandler_GUIClientId[i].clientId); | |
//var Result vl_result | |
//f_EPTF_Transport_send(IPL4, v_UIHandler_GUIClientId[i], char2oct("bye\r\n"), vl_result, false) | |
} | |
} | |
f_EPTF_Semaphore_delete(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
f_EPTF_Semaphore_delete(v_UIHandler_layoutResponseReceivedSemaphore); | |
f_EPTF_Semaphore_delete(v_UIHandler_exitButtonPressedSemaphore); | |
v_UIHandler_openSubscriptions := {}; | |
v_UIHandler_subscriptions := {} | |
f_EPTF_str2int_HashMap_Delete(c_EPTF_UIHandler_subscriptionHashMapName); | |
f_EPTF_str2int_HashMap_Delete(c_EPTF_UIHandler_subscriptionHashMapNameVar); | |
f_EPTF_str2int_HashMap_Delete(c_EPTF_UIHandler_simulation_varsHashMapName); | |
v_UIHandler_subscriptionHashMapId := -1; | |
v_UIHandler_subscriptionHashMapIdVar := -1; | |
v_UIHandler_simulation_varsHashMapId := -1; | |
v_UIHandler_guiItemList := {}; | |
v_UIHandler_windowIndex := -1; | |
v_UIHandler_initialized := false; | |
f_EPTF_str2int_HashMap_Delete(c_EPTF_UIHandler_widgetIdHashMapName); | |
v_UIHandler_widgetHashMapId := -1; | |
f_EPTF_int2int_HashMap_Delete(c_EPTF_UIHandler_tracePointerHashMapName); | |
v_UIHandler_tracePointerHashMapId := -1; | |
v_UIHandler_tracePointers := {}; | |
f_EPTF_str2int_HashMap_DeleteById(v_EPTF_UIHandler_Traces_HashmapId); | |
v_EPTF_UIHandler_TraceRingBuffers := {}; | |
v_UIHandler_initToGUIClient := false; | |
v_UIHandler_createGUIRunning := false; | |
v_EPTF_UIHandler_headlessmode := true; | |
v_EPTF_UIHandler_servermode := false; | |
v_EPTF_UIHandler_Authresp := ""; | |
} | |
// Reset the GUI address because we don't want to affect the | |
// subsequence UIHandler initializations. | |
v_UIHandler_GUI_Host := c_EPTF_UIHandler_Invalid_GUI_Host; | |
v_UIHandler_GUI_Port := c_EPTF_UIHandler_Invalid_GUI_Port; | |
v_UIHandler_guiConnected := false; | |
// clearing registered callbacks (also registered callbacks exit if not v_UIHandler_initialized): | |
//f_EPTF_CommPort_IPL4_setMsgLen4LGenType(null, {}, c_EPTF_UIHandler_XTDPType); | |
f_EPTF_Transport_registerMsgCallback(IPL4, c_EPTF_UIHandler_XTDPType, null, null); | |
deactivate(v_UIHandler_def); v_UIHandler_def := null; | |
// WORKAROUND for some GUI bug, remove it ASAP! | |
timer t_x := 0.5;t_x.start;t_x.timeout; | |
if (not v_EPTF_UIHandler_servermode){ | |
var Result vl_result | |
f_EPTF_Transport_close(IPL4, v_UIHandler_pingerConnectionId, vl_result) | |
v_UIHandler_pingerConnectionId := -1; | |
} | |
f_EPTF_UIHandler_CLIClient_cleanup_CT() | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug("----EPTF_UIHandler cleanup DONE----"); | |
} | |
f_EPTF_UIHandler_cleanup_XML(); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_clearGUI | |
// | |
// Purpose: | |
// Sends a message to user interface via XTDP port to remove | |
// all the elements and also clears UIHandler's internal DB. | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_clearGUI(in boolean pl_clearDb := true) runs on EPTF_UIHandler_Private_CT { | |
if (not v_UIHandler_initialized){ return } | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
// remove all | |
for(var integer clientindex:=0;clientindex<sizeof(v_UIHandler_GUIClientId);clientindex := clientindex+1){ | |
var ASP_XSD_XTDP vl_msg :={ | |
v_UIHandler_GUIClientId[clientindex].clientId, | |
{ | |
choice := { | |
xTDP_RemoveRequests:= { | |
xTDP_RemoveRequest_list := { | |
{ | |
requestId := 1, | |
widgetId := omit | |
} | |
} | |
} | |
} | |
} | |
}; | |
f_EPTF_UIHandler_send_XTDP(vl_msg); | |
} | |
if (pl_clearDb) { | |
// make internal widget DB empty | |
f_EPTF_UIHandler_clearInternalWidgetDB(); | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addWindow | |
// | |
// Purpose: | |
// Tries to add a new window to the RuntimeGUI | |
// | |
// Detailed Comments: | |
// The parameters of the new window can be controlled via | |
// the tsp_EPTF_GUI_Main_Window_... module parameters | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_addWindow() | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
if (not v_UIHandler_initialized){ return false } | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var Widgets vl_xul := { | |
window := { | |
about := omit, | |
height := tsp_EPTF_GUI_Main_Window_Height, | |
help := omit, | |
id := tsp_EPTF_GUI_Main_Window_WidgetId, | |
orientation := vertical, | |
title := tsp_EPTF_GUI_Main_Window_Title, | |
width := tsp_EPTF_GUI_Main_Window_Width, | |
image_list := {}, | |
embeddedwidgets := { | |
/* {tabbox := { */ | |
/* id := tsp_EPTF_GUI_Main_Tabbox_WidgetId, */ | |
/* flex := omit, */ | |
/*customclass := omit, */ | |
/* disabled := omit, */ | |
/*disabledongui := omit, */ | |
/* tabs := {}, */ | |
/* tabpanels := {} */ | |
/* } */ | |
/* }, */ | |
embeddedwidget_list := { | |
/*{ | |
toolbar := { | |
customclass := omit, | |
disabled := false, | |
disabledongui := omit, | |
id := tsp_EPTF_GUI_Main_Toolbar_WidgetId, | |
placement := south, | |
choice_list := {} | |
} | |
}*/ | |
} | |
} | |
} | |
}; | |
var boolean vl_dummy := false; | |
return f_EPTF_UIHandler_XSD_addElementToGui(vl_xul, "", vl_dummy); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addMainTabbox | |
// | |
// Purpose: | |
// Tries to add the main tabbox to the RuntimeGUI | |
// | |
// Detailed Comments: | |
// The id of the tabbox is spesified by | |
// tsp_EPTF_GUI_Main_Tabbox_WidgetId module parameter | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_addMainTabbox() | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
if (not v_UIHandler_initialized){ return false } | |
var boolean vl_succ := f_EPTF_UIHandler_addMainTabpages(); | |
return vl_succ; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addMainTabpages | |
// | |
// Purpose: | |
// Tries to add the main tabbox to the RuntimeGUI | |
// | |
// Detailed Comments: | |
// The id of the tabbox is spesified by | |
// tsp_EPTF_GUI_Main_Tabbox_WidgetId module parameter | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_addMainTabpages() | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
if (not v_UIHandler_initialized){ return false } | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var Widgets vl_xul := { | |
tabpages := { | |
//In case of named fields the compiler won't warn if | |
//there are uninitializad elements | |
/*customclass :=*/ omit, | |
/*disabled :=*/ omit, | |
/*disabledongui :=*/ omit, | |
/*flex :=*/ omit, | |
/*id :=*/ tsp_EPTF_GUI_Main_Tabbox_WidgetId, | |
/*layout :=*/ omit, | |
/*tabpage :=*/ { { } } | |
} | |
}; | |
var boolean vl_dummy:=false; | |
return f_EPTF_UIHandler_XSD_addElementToGui(vl_xul, tsp_EPTF_GUI_Main_Window_WidgetId, vl_dummy); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeElementFromGui | |
// | |
// Purpose: | |
// Remove an element from the GUI. | |
// | |
// Parameters: | |
// pl_widgetId - *in* *EPTF_UIHandler_WidgetIdString* - element to be removed | |
// pl_sendToRTG - *in* *boolean* - if true: request is sent to runtime GUI, otherwise not | |
// | |
// Return Value: | |
// Returns the result of f_EPTF_UIHandler_removeWidgetRecByIdx. | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_removeElementFromGui_old(in EPTF_UIHandler_WidgetIdString pl_widgetId, in boolean pl_sendToRTG := true, in boolean pl_appendTo_GUI_DescriptionDB := true) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
if (not v_UIHandler_initialized){ return false } | |
if(pl_appendTo_GUI_DescriptionDB) { | |
v_UIHandler_GUI_DescriptionDB[sizeof(v_UIHandler_GUI_DescriptionDB)] := {pl_widgetId, "removed"}; | |
} | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var integer vl_idx := f_EPTF_UIHandler_widgetRecIndex(pl_widgetId); | |
if(-1 == vl_idx){ | |
f_EPTF_UIHandler_warning("There is no widget with name "&pl_widgetId&" to remove!"); | |
return false; | |
} | |
//remove the element from the GUI | |
if (pl_sendToRTG) { | |
f_EPTF_UIHandler_send_XTDP(ts_ASP_XTDP_singleRemoveElementFromGUI(pl_widgetId)); | |
} | |
if(tsp_EPTF_UIHandler_enableBrowserGUI == true){ | |
f_EPTF_UIHandler_Browser_reportGUIChanged(pl_widgetId); | |
} | |
//remove it and its children from the widgetlist and the connectionlist | |
return f_EPTF_UIHandler_removeWidgetRecByIdx(vl_idx); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeElementFromGui | |
// | |
// Purpose: | |
// Remove an element from the GUI. | |
// | |
// Parameters: | |
// pl_widgetId - *in* *EPTF_UIHandler_WidgetIdString* - element to be removed | |
// pl_sendToRTG - *in* *boolean* - if true: request is sent to runtime GUI, otherwise not | |
// | |
// Return Value: | |
// Returns the result of f_EPTF_UIHandler_removeWidgetRecByIdx. | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_removeElementFromGui(in EPTF_UIHandler_WidgetIdString pl_widgetId, in boolean pl_sendToRTG := true, in boolean pl_appendTo_GUI_DescriptionDB := true) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
if (not v_UIHandler_initialized){ return false } | |
var boolean vl_ret := true; | |
if(pl_appendTo_GUI_DescriptionDB) { | |
v_UIHandler_GUI_DescriptionDB[sizeof(v_UIHandler_GUI_DescriptionDB)] := {pl_widgetId, "removed"}; | |
} | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var integer vl_idx := f_EPTF_UIHandler_widgetRecIndex(pl_widgetId); | |
if(-1 == vl_idx){ | |
f_EPTF_UIHandler_warning("There is no widget with name "&pl_widgetId&" to remove!"); | |
return false; | |
} | |
//remove the element from the GUI | |
if (pl_sendToRTG) { | |
f_EPTF_UIHandler_send_XTDP(ts_ASP_XTDP_singleRemoveElementFromGUI(pl_widgetId)); | |
} | |
if(tsp_EPTF_UIHandler_enableBrowserGUI == true){ | |
f_EPTF_UIHandler_Browser_reportGUIChanged(pl_widgetId); | |
} | |
//remove it and its children from the widgetlist and the connectionlist | |
vl_ret := f_EPTF_UIHandler_removeWidgetRecByIdx(vl_idx) | |
if(vl_ret == true) { | |
// Remove it from document | |
vl_ret := f_EPTF_UIHandler_removeXML(pl_widgetId); | |
} | |
return vl_ret; | |
} | |
public function f_EPTF_UIHandler_printAllXMLfor_Tests( ) | |
runs on EPTF_UIHandler_Private_CT { | |
if (not v_UIHandler_initialized){ return } | |
f_EPTF_UIHandler_printAllXML(); | |
return; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeElementFromGuiByIdx | |
// | |
// Purpose: | |
// Remove an element from the GUI. | |
// | |
// Parameters: | |
// pl_widgetIdx - *in* *integer* - element to be removed | |
// pl_sendToRTG - *in* *boolean* - if true: request is sent to runtime GUI, otherwise not | |
// | |
// Return Value: | |
// Returns the result of f_EPTF_UIHandler_removeWidgetRecByIdx. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_removeElementFromGuiByIdx(in integer pl_widgetIdx, in boolean pl_sendToRTG := true, in boolean pl_appendTo_GUI_DescriptionDB := true) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var charstring vl_widgetId := v_UIHandler_guiItemList[pl_widgetIdx].id; | |
if(pl_appendTo_GUI_DescriptionDB) { | |
v_UIHandler_GUI_DescriptionDB[sizeof(v_UIHandler_GUI_DescriptionDB)] := {vl_widgetId, "removed"}; | |
} | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
if(-1 == pl_widgetIdx){ | |
f_EPTF_UIHandler_warning("There is no widget with name "&vl_widgetId&" to remove!"); | |
return false; | |
} | |
//remove the element from the GUI | |
if (pl_sendToRTG) { | |
f_EPTF_UIHandler_send_XTDP(ts_ASP_XTDP_singleRemoveElementFromGUI(vl_widgetId)); | |
} | |
if(tsp_EPTF_UIHandler_enableBrowserGUI == true){ | |
f_EPTF_UIHandler_Browser_reportGUIChanged(vl_widgetId, pl_widgetIdx); | |
} | |
//remove it and its children from the widgetlist and the connectionlist | |
return f_EPTF_UIHandler_removeWidgetRecByIdx(pl_widgetIdx); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_snapshot | |
// | |
// Purpose: | |
// Makes a snapshot of the GUI as a charstring. | |
// | |
// Return Value: | |
// The returned charstring describes a XUL. It can be saved with | |
// <f_EPTF_UIHandler_saveLayout> to a config file. | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_snapshot() | |
runs on EPTF_UIHandler_Private_CT | |
return charstring{ | |
if (not v_UIHandler_initialized){ return "" } | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var charstring vl_layout := ""; | |
if(v_UIHandler_guiConnected) | |
{ | |
f_EPTF_UIHandler_send_XTDP(ts_ASP_XTDP_layoutRequest); | |
if(f_EPTF_Semaphore_waitForUnlock(v_UIHandler_layoutResponseReceivedSemaphore, tsp_EPTF_UIHandler_maxWaitTimer)) | |
{ | |
f_EPTF_UIHandler_warning("Timer timeout! No layout response received!"); | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
v_UIHandler_layoutResponseReceivedSemaphore := f_EPTF_Semaphore_new(); | |
return vl_layout; | |
} | |
v_UIHandler_layoutResponseReceivedSemaphore := f_EPTF_Semaphore_new(); | |
//f_EPTF_Semaphore_lock(v_UIHandler_layoutResponseReceivedSemaphore); | |
vl_layout := f_EPTF_UIHandler_XSD_encodeXUL(v_UIHandler_receivedMessage.choice.xTDP_LayoutResponse.widgets); | |
}else{ | |
var Widgets vl_xul; | |
f_EPTF_UIHandler_buildXUL(vl_xul); | |
vl_layout := f_EPTF_UIHandler_XSD_encodeXUL(vl_xul) | |
} | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
return vl_layout; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_snapshotWindow | |
// | |
// Purpose: | |
// Makes a snapshot of the GUI's root widget (windowelem) as a charstring. | |
// | |
// Return Value: | |
// The returned charstring describes a XUL that can be passed to | |
// the runtime GUI as a command line parameter if saved as a file. | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_snapshotWindow() | |
runs on EPTF_UIHandler_Private_CT | |
return charstring{ | |
if (not v_UIHandler_initialized){ return "" } | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var charstring vl_layout := ""; | |
if(v_UIHandler_guiConnected) | |
{ | |
f_EPTF_UIHandler_send_XTDP(ts_ASP_XTDP_layoutRequest); | |
if(f_EPTF_Semaphore_waitForUnlock(v_UIHandler_layoutResponseReceivedSemaphore, tsp_EPTF_UIHandler_maxWaitTimer)) | |
{ | |
f_EPTF_UIHandler_warning("Timer timeout! No layout response received!"); | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
v_UIHandler_layoutResponseReceivedSemaphore := f_EPTF_Semaphore_new(); | |
return vl_layout; | |
} | |
v_UIHandler_layoutResponseReceivedSemaphore := f_EPTF_Semaphore_new(); | |
//f_EPTF_Semaphore_lock(v_UIHandler_layoutResponseReceivedSemaphore); | |
if(ischosen(v_UIHandler_receivedMessage.choice.xTDP_LayoutResponse.widgets.window)) { | |
vl_layout := f_EPTF_UIHandler_XSD_encodeWindowXUL(v_UIHandler_receivedMessage.choice.xTDP_LayoutResponse.widgets.window); | |
} else { | |
f_EPTF_UIHandler_warning(%definitionId&": Unexpected XTDP LayoutResponse (not window)!"); | |
} | |
}else{ | |
var Widgets vl_xul; | |
f_EPTF_UIHandler_buildXUL(vl_xul); | |
if(ischosen(vl_xul.window)) { | |
vl_layout := f_EPTF_UIHandler_XSD_encodeWindowXUL(vl_xul.window); | |
} else { | |
f_EPTF_UIHandler_warning(%definitionId&": Unexpected layout (not window)!"); | |
} | |
} | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
return vl_layout; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_XSD_encodeXUL | |
// | |
// Purpose: | |
// Encodes a XUL record to its charstring representation | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_XSD_encodeXUL(in Widgets pl_widgets) | |
return charstring{ | |
var octetstring vl_ret := enc_Widgets(pl_widgets); | |
return oct2char(vl_ret) | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_XSD_encodeWindowXUL | |
// | |
// Purpose: | |
// Encodes a XUL Window record to its charstring representation | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_XSD_encodeWindowXUL(in Window pl_windowelem) | |
return charstring{ | |
var octetstring vl_ret := enc_Window(pl_windowelem); | |
return oct2char(vl_ret) | |
} | |
public external function dec_Widgets (in octetstring p_oct, out Widgets p_widgets) return integer | |
with {extension "prototype(backtrack) decode (XER:XER_EXTENDED) errorbehavior(ALL:WARNING)"} | |
public external function enc_Widgets (in Widgets p_widgets) return octetstring | |
with {extension "prototype(convert) encode (XER:XER_EXTENDED)"} | |
public external function enc_Window (in Window p_windowelem) return octetstring | |
with {extension "prototype(convert) encode (XER:XER_EXTENDED)"} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_XSD_encodeXULEm | |
// | |
// Purpose: | |
// Encodes an Embedded XUL record to its charstring representation | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_XSD_encodeXULEm(in Embeddedwidget pl_widgets) | |
return charstring{ | |
var octetstring vl_ret := enc_EmbeddedWidget(pl_widgets); | |
return oct2char(vl_ret) | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_preprocessAliasXUL | |
// | |
// Purpose: | |
// Preprocess alias items in XUL charstring | |
// | |
/////////////////////////////////////////////////////////// | |
// 02.04.2012 made for first version of externalvalue | |
// handling. not dropped becouse it will be useful once. | |
type record EPTF_UIHandler_alias { | |
charstring fromStr, | |
charstring toStr | |
}; | |
type record of EPTF_UIHandler_alias EPTF_UIHandler_aliasList; | |
public function f_EPTF_UIHandler_preprocessAliasXUL(in charstring pl_xul) | |
runs on EPTF_UIHandler_Private_CT return charstring { | |
var EPTF_UIHandler_aliasList vl_aliasList:= {/*{ fromStr := "externalvalue", toStr := "iterator" }*/}; | |
var charstring vl_preprocessed := pl_xul; | |
if(0 < sizeof(vl_aliasList)) { | |
for (var integer vl_idx := 0; vl_idx < sizeof(vl_aliasList); vl_idx := vl_idx + 1) { | |
var charstring vl_startFromValue := "<"&vl_aliasList[vl_idx].fromStr; | |
var charstring vl_startToValue := "<"&vl_aliasList[vl_idx].toStr; | |
var charstring vl_endFromValue := "</"&vl_aliasList[vl_idx].fromStr; | |
var charstring vl_endToValue := "</"&vl_aliasList[vl_idx].toStr; | |
// replace start tag | |
vl_preprocessed := pl_xul; | |
var charstring vl_tempStr:= pl_xul; | |
var charstring vl_LoverStr := f_putInLowercase(pl_xul), vl_tempLowerStr:= vl_LoverStr; | |
var integer vl_i := f_strstr(vl_LoverStr,vl_startFromValue); | |
while (vl_i!=-1) { | |
vl_preprocessed := | |
substr(vl_tempStr,0,vl_i)&vl_startToValue& | |
substr(vl_tempStr,vl_i+lengthof(vl_startFromValue), | |
lengthof(vl_tempStr)-vl_i-lengthof(vl_startFromValue)); | |
vl_LoverStr := substr(vl_tempLowerStr,0,vl_i)&vl_startToValue& | |
substr(vl_tempLowerStr,vl_i+lengthof(vl_startFromValue), | |
lengthof(vl_tempLowerStr)-vl_i-lengthof(vl_startFromValue)); | |
//continue from saved pointer offset with the length of replacement string | |
vl_i := vl_i+lengthof(vl_startToValue); | |
vl_tempStr := vl_preprocessed; | |
vl_tempLowerStr := vl_LoverStr; | |
vl_i := f_strstr(vl_LoverStr,vl_startFromValue,vl_i); | |
} | |
// replace end tag | |
vl_tempStr:= vl_preprocessed; | |
vl_tempLowerStr:= vl_LoverStr; | |
vl_i := f_strstr(vl_LoverStr,vl_endFromValue); | |
while (vl_i!=-1) { | |
vl_preprocessed := | |
substr(vl_tempStr,0,vl_i)&vl_endToValue& | |
substr(vl_tempStr,vl_i+lengthof(vl_endFromValue), | |
lengthof(vl_tempStr)-vl_i-lengthof(vl_endFromValue)); | |
vl_LoverStr := substr(vl_tempLowerStr,0,vl_i)&vl_endToValue& | |
substr(vl_tempLowerStr,vl_i+lengthof(vl_endFromValue), | |
lengthof(vl_tempLowerStr)-vl_i-lengthof(vl_endFromValue)); | |
//continue from saved pointer offset with the length of replacement string | |
vl_i := vl_i+lengthof(vl_endToValue); | |
vl_tempStr := vl_preprocessed; | |
vl_tempLowerStr := vl_LoverStr; | |
vl_i := f_strstr(vl_LoverStr,vl_endFromValue,vl_i); | |
} | |
} | |
} | |
return vl_preprocessed; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_XSD_decodeXULEm | |
// | |
// Purpose: | |
// Decodes a XUL record to its charstring representation | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_XSD_decodeXULEm(in charstring pl_widgets) | |
return Embeddedwidget{ | |
var Embeddedwidget vl_ret; | |
var integer vl_dummy; | |
vl_dummy := dec_EmbeddedWidget(char2oct(pl_widgets), vl_ret); | |
return vl_ret; | |
} | |
private external function dec_EmbeddedWidget (in octetstring p_oct, out Embeddedwidget p_widgets) return integer | |
with {extension "prototype(backtrack) decode (XER:XER_EXTENDED) errorbehavior(ALL:WARNING)"} | |
private external function enc_EmbeddedWidget (in Embeddedwidget p_widgets) return octetstring | |
with {extension "prototype(convert) encode (XER:XER_EXTENDED)"} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_XSD_decodeXUL | |
// | |
// Purpose: | |
// Decodes a XUL record to its charstring representation | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_XSD_decodeXUL(in charstring pl_widgets) | |
runs on EPTF_UIHandler_Private_CT | |
return Widgets{ | |
var Widgets vl_ret; | |
var integer vl_retval; | |
vl_retval := dec_Widgets(char2oct(pl_widgets), vl_ret); | |
if(0 != vl_retval){ | |
f_EPTF_UIHandler_error(%definitionId&": The received XML is invalid, it can not be decoded fully.\n"& | |
"For further detailes see the log file above.") | |
} | |
return vl_ret; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_saveLayout | |
// | |
// Purpose: | |
// Saves the parameter charstring as a window layout. | |
// | |
// Detailed Comments: | |
// The layout of the window can be retreived with the function | |
// <f_EPTF_UIHandler_snapshot>. | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_saveLayout(in charstring pl_layout) | |
runs on EPTF_UIHandler_Private_CT{ | |
f_EPTF_UIHandler_waitForLayoutReady(); | |
var charstring vl_currentConfig := "\n// saved by EPTF GUI\n\n[MODULE_PARAMETERS]\n\ntsp_EPTF_GUI_DefaultWindow := """ & f_EPTF_UIHandler_convertLayout(pl_layout) & """"; | |
var charstring vl_FileName := f_getTimeFormatted(f_time(),tsp_EPTF_savedGUIPrefix & "_%d%m%Y_%H_%M.cfg"); | |
var integer vl_file := f_FIO_open_trunc_wronly(vl_FileName); | |
if(-1 != vl_file){ | |
if(-1 == f_FIO_write_text(vl_file, vl_currentConfig)){ | |
f_EPTF_UIHandler_warning("Couldn't write file "&vl_FileName&"."); | |
var integer int := f_FIO_close(vl_file); | |
if (int == -1){ | |
f_EPTF_UIHandler_warning("Could not close the file!"); | |
} | |
// f_EPTF_Base_stop(); | |
}else{ | |
var integer int := f_FIO_close(vl_file); | |
if (int == -1){ | |
f_EPTF_UIHandler_warning("Could not close the file!"); | |
} | |
} | |
}else{ | |
f_EPTF_UIHandler_warning("Couldn't open file "&vl_FileName&" for writing."); | |
// f_EPTF_Base_stop(); | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_logAll | |
// | |
// Purpose: | |
// Logs all internal variables in EPTF_UIHandler_CT. | |
// | |
// Detailed Comments: | |
// - | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_logAll() runs on EPTF_UIHandler_Private_CT { | |
log("------Content of EPTF_UIHandler_CT: -------"); | |
//log("v_UIHandler_CLI_initialized: ", v_UIHandler_CLI_initialized); | |
log("v_UIHandler_initialized: ", v_UIHandler_initialized); | |
log("v_UIHandler_lastRequest: ", v_UIHandler_lastRequest); | |
log("v_UIHandler_guiConnected: ",v_UIHandler_guiConnected); | |
log("v_UIHandler_windowLayout: ", v_UIHandler_windowLayout); | |
log("v_UIHandler_guiLayoutReady: ", v_UIHandler_guiLayoutReady); | |
log("v_UIHandler_guiItemList: ",v_UIHandler_guiItemList); | |
log("t_UIHandler_pingtimer: ",t_UIHandler_pingtimer); | |
log("v_UIHandler_succpingcounter: ",v_UIHandler_succpingcounter); | |
log("v_UIHandler_pingcounter", v_UIHandler_pingcounter); | |
log("v_UIHandler_prevpingcounter: ", v_UIHandler_prevpingcounter); | |
log("v_UIHandler_def: ",v_UIHandler_def); | |
log("v_UIHandler_openSubscriptions: ",v_UIHandler_openSubscriptions); | |
log("v_UIHandler_subscriptions: ", v_UIHandler_subscriptions); | |
log("v_UIHandler_windowIndex: ",v_UIHandler_windowIndex); | |
log("v_UIHandler_GUIClientId: ",v_UIHandler_GUIClientId); | |
log("v_UIHandler_lastRowId: ",v_UIHandler_lastRowId); | |
log("v_UIHandler_subscriptInProcess: ", v_UIHandler_subscriptInProcess); | |
log("t_UIHandler_bufferedXTDP: ",t_UIHandler_bufferedXTDP ); | |
log("t_UIHandler_initGUIToClientTimer: ",t_UIHandler_initGUIToClientTimer ); | |
log("------Finished Content of EPTF_UIHandler_CT -------"); | |
}//f_ | |
public function f_EPTF_UIHandler_logWidgetDB(in boolean pl_verbose := false) | |
runs on EPTF_UIHandler_Private_CT | |
return charstring{ | |
if (not v_UIHandler_initialized){ return "" } | |
var charstring vl_log := "" | |
for ( var integer i := 0, s := sizeof(v_UIHandler_guiItemList); i < s ; i := i+1 ){ | |
f_EPTF_UIHandler_log2strWidgetRec(i,vl_log, pl_verbose) | |
vl_log := vl_log & "\n"; | |
} | |
return vl_log; | |
} | |
public function f_EPTF_UIHandler_log2strWidgetRec( | |
in integer pl_recIdx, | |
inout charstring pl_ret, | |
in boolean pl_verbose := false) | |
runs on EPTF_UIHandler_Private_CT{ | |
if (not v_UIHandler_initialized){ return } | |
pl_ret := pl_ret&"Idx:\t"&log2str(pl_recIdx)& | |
"\nID:\t"&v_UIHandler_guiItemList[pl_recIdx].id& | |
"\nType:\t"&log2str(v_UIHandler_guiItemList[pl_recIdx].widgetType) | |
if(pl_verbose){ | |
pl_ret := pl_ret & "\nData type\t"&log2str(v_UIHandler_guiItemList[pl_recIdx].widgetDataType) | |
} | |
pl_ret := pl_ret & "\nParent:\t"&log2str(v_UIHandler_guiItemList[pl_recIdx].parentIdx)& | |
"\nChildren:\t"; | |
for ( var integer j:=0, sc := sizeof(v_UIHandler_guiItemList[pl_recIdx].children); j < sc ; j := j+1 ){ | |
pl_ret := pl_ret & int2str(v_UIHandler_guiItemList[pl_recIdx].children[j])&", "; | |
} | |
if(pl_verbose){ | |
pl_ret := pl_ret & log2str(v_UIHandler_guiItemList[pl_recIdx].widgetData); | |
} | |
//Widgets XULformat optional | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_GUIConnected | |
// | |
// Purpose: | |
// Returns whether the GUI is connected (authenticated) | |
// | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_GUIConnected() runs on EPTF_UIHandler_Private_CT return boolean { | |
return v_UIHandler_guiConnected | |
} | |
public function f_EPTF_UIHandler_initialized() runs on EPTF_UIHandler_Private_CT return boolean { | |
return v_UIHandler_initialized; | |
}//f_ | |
friend function f_EPTF_UIHandler_guiItemList() runs on EPTF_UIHandler_Private_CT return EPTF_UIHandler_GuiItemRecList { | |
return v_UIHandler_guiItemList; | |
} | |
friend function f_EPTF_UIHandler_openSubscriptions() runs on EPTF_UIHandler_Private_CT return EPTF_UIHandler_OpenSubscriptions { | |
return v_UIHandler_openSubscriptions; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_exitButtonPressed | |
// | |
// Purpose: | |
// Handles the pressing of the exit button. Only for TESTING purposes! | |
// | |
// Detailed Comments: | |
// - | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_exitButtonPressed(in float pl_timeout := tsp_EPTF_UIHandler_maxWaitTimer) runs on EPTF_UIHandler_Private_CT { | |
if (not v_UIHandler_initialized){ return } | |
{ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": Waiting for the exit button to be pressed."); | |
} | |
if(f_EPTF_Semaphore_waitForUnlock(v_UIHandler_exitButtonPressedSemaphore, pl_timeout)) | |
{ | |
f_EPTF_UIHandler_warning(%definitionId&": Timer timeout! Exit button was not pressed!"); | |
} | |
v_UIHandler_exitButtonPressedSemaphore := f_EPTF_Semaphore_new(); | |
//f_EPTF_Semaphore_lock(v_UIHandler_exitButtonPressedSemaphore); | |
}; | |
} | |
} // group PublicFunctions | |
//========================================================================= | |
// Private functions | |
//========================================================================= | |
group PrivateFunctions { | |
private function f_EPTF_UIHandler_requestBuffer_clear() | |
runs on EPTF_UIHandler_Private_CT | |
{ | |
v_UIHandler_RequestbufferIsEmpty := true; | |
v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.xTDP_Request_list := { c_UIHandler_XSD_emptyXTDPRequest }; | |
} | |
private function f_EPTF_UIHandler_requestBuffer_size() | |
runs on EPTF_UIHandler_Private_CT | |
return integer | |
{ | |
if (v_UIHandler_RequestbufferIsEmpty) { | |
return 0; | |
} else { | |
return sizeof(v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.xTDP_Request_list); | |
} | |
} | |
private function f_EPTF_UIHandler_requestBuffer_add(in ttcn_ericsson_se_protocolModules_xtdp_xtdp.XTDP_Request pl_request) | |
runs on EPTF_UIHandler_Private_CT | |
{ | |
var integer i := 0; | |
if (not v_UIHandler_RequestbufferIsEmpty) { | |
i := sizeof(v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.xTDP_Request_list); | |
} | |
v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.xTDP_Request_list[i] := pl_request; | |
v_UIHandler_RequestbufferIsEmpty := false; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_convertLayout | |
// | |
// Purpose: | |
// Converts the charstring retreived by the <f_EPTF_UIHandler_snapshot> | |
// function to a storeable format. (Changes the ", \n and \ characters.) | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_convertLayout(in charstring pl_layout) | |
runs on EPTF_UIHandler_Private_CT | |
return charstring{ | |
var charstring vl_ret := ""; | |
var integer vl_len := lengthof(pl_layout); | |
for(var integer vl_i := 0; vl_i < vl_len; vl_i := vl_i + 1){ | |
select(substr(pl_layout,vl_i,1)){ | |
case(""""){ vl_ret := vl_ret & "\\""";} | |
case("\n"){ vl_ret := vl_ret & "\\n";} | |
case("\\"){ vl_ret := vl_ret & "\\\\";} | |
case else {vl_ret := vl_ret & pl_layout[vl_i];} | |
} | |
} | |
return vl_ret; | |
} | |
// /////////////////////////////////////////////////////////// | |
// // Function: f_EPTF_UIHandler_saveXul | |
// // | |
// // Purpose: | |
// // Saves the parameter charstring as a window layout. | |
// // | |
// // Detailed Comments: | |
// // The layout of the window can be retreived with the function | |
// // <f_EPTF_UIHandler_snapshot>. | |
// /////////////////////////////////////////////////////////// | |
// private function f_EPTF_UIHandler_saveXul(in Widgets pl_xul) | |
// runs on EPTF_UIHandler_Private_CT{ | |
// var charstring vl_layout := f_EPTF_UIHandler_XSD_encodeXUL(pl_xul); | |
//// var charstring vl_currentConfig := f_EPTF_UIHandler_convertLayout(vl_layout); | |
// var charstring vl_FileName := f_getTimeFormatted(f_time(),tsp_EPTF_savedGUIPrefix & "_%d%m%Y_%H_%M.xml"); | |
// var integer vl_file := f_FIO_open_trunc_wronly(vl_FileName); | |
// if(-1 != vl_file){ | |
//// if(-1 == f_FIO_write_text(vl_file, vl_currentConfig)){ | |
// if(-1 == f_FIO_write_text(vl_file, vl_layout)){ | |
// f_EPTF_UIHandler_warning("Couldn't write file "&vl_FileName&"."); | |
// var integer vl_dummy := f_FIO_close(vl_file); | |
// if (vl_dummy == -1){ | |
// f_EPTF_UIHandler_warning("Could not close the file!"); | |
// } | |
// // f_EPTF_Base_stop(); | |
// }else{ | |
// var integer vl_dummy := f_FIO_close(vl_file); | |
// if (vl_dummy == -1){ | |
// f_EPTF_UIHandler_warning("Could not close the file!"); | |
// } | |
// } | |
// }else{ | |
// f_EPTF_UIHandler_warning("Couldn't open file "&vl_FileName&" for writing."); | |
// // f_EPTF_Base_stop(); | |
// } | |
// } | |
// | |
// /////////////////////////////////////////////////////////// | |
// // Function: f_EPTF_UIHandler_saveWidgets | |
// // | |
// // Purpose: | |
// // Saves content of the GUI database. | |
// // | |
// // Detailed Comments: | |
// // - | |
// /////////////////////////////////////////////////////////// | |
// private function f_EPTF_UIHandler_saveWidgets() | |
// runs on EPTF_UIHandler_Private_CT{ | |
// | |
// var charstring vl_widget_info := ""; | |
// var integer limit := sizeof(v_UIHandler_guiItemList); | |
// for (var integer i := 0; i < limit ; i := i+1 ) | |
// { | |
// vl_widget_info := vl_widget_info&"\n"&int2str(i)&" widget= "&log2str(v_UIHandler_guiItemList[i]); | |
// } | |
// | |
// var charstring vl_FileName := f_getTimeFormatted(f_time(),"widgetList" & "_%d%m%Y_%H_%M.xml"); | |
// var integer vl_file := f_FIO_open_trunc_wronly(vl_FileName); | |
// if(-1 != vl_file){ | |
//// if(-1 == f_FIO_write_text(vl_file, vl_currentConfig)){ | |
// if(-1 == f_FIO_write_text(vl_file, vl_widget_info)){ | |
// f_EPTF_UIHandler_warning("Couldn't write file "&vl_FileName&"."); | |
// var integer vl_dummy := f_FIO_close(vl_file); | |
// if (vl_dummy == -1){ | |
// f_EPTF_UIHandler_warning("Could not close the file!"); | |
// } | |
// // f_EPTF_Base_stop(); | |
// }else{ | |
// var integer vl_dummy := f_FIO_close(vl_file); | |
// if (vl_dummy == -1){ | |
// f_EPTF_UIHandler_warning("Could not close the file!"); | |
// } | |
// } | |
// }else{ | |
// f_EPTF_UIHandler_warning("Couldn't open file "&vl_FileName&" for writing."); | |
// // f_EPTF_Base_stop(); | |
// } | |
// } | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_revertLayout | |
// | |
// Purpose: | |
// Restores the charstring converted by the <f_EPTF_UIHandler_convertLayout> | |
// to a charstring that can be given to | |
/////////////////////////////////////////////////////////// | |
public function f_EPTF_UIHandler_revertLayout(in charstring pl_layout) | |
runs on EPTF_UIHandler_Private_CT | |
return charstring{ | |
var charstring vl_ret := ""; | |
var integer vl_len := lengthof(pl_layout); | |
for(var integer vl_i := 0; vl_i < vl_len; vl_i := vl_i + 1){ | |
if("\\" == substr(pl_layout,vl_i,1) and vl_i < vl_len-1){ | |
select(substr(pl_layout,vl_i+1,1)){ | |
case(""""){ | |
vl_ret := vl_ret & """"; | |
vl_i := vl_i + 1; | |
} | |
case("n"){ | |
vl_ret := vl_ret & "\n"; | |
vl_i := vl_i + 1; | |
} | |
case("\\"){ | |
vl_ret := vl_ret & "\\"; | |
vl_i := vl_i + 1; | |
} | |
case else { | |
f_EPTF_UIHandler_warning("Invalid \\ character in layout string at "&int2str(vl_i)); | |
} | |
} | |
}else{ | |
vl_ret := vl_ret & pl_layout[vl_i]; | |
} | |
} | |
return vl_ret; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_send_XTDP | |
// | |
// Purpose: | |
// function to send a message to user interface via XTDP port | |
// | |
// Parameters: | |
// pl_msg - *in* *template ASP_XTDP* - XTDP message template ONLY one message! | |
// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_send_XTDP(in template ASP_XSD_XTDP pl_msg) runs on EPTF_UIHandler_Private_CT | |
{ | |
if (v_UIHandler_guiConnected) | |
{ | |
v_UIHandler_lastRequest := v_UIHandler_lastRequest + 1; | |
pl_msg.data.transactionID := v_UIHandler_lastRequest; | |
if(ischosen(pl_msg.data.choice.xTDP_Requests)) | |
{ | |
pl_msg.data.choice.xTDP_Requests.xTDP_Request_list[0].requestId := v_UIHandler_lastRequest; | |
if (tsp_EPTF_UIHandler_bufferedXTDP != 0.0) | |
{ | |
v_UIHandler_Requestbuffer.client_id := omit; | |
for (var integer i := 0; i < sizeof(pl_msg.data.choice.xTDP_Requests.xTDP_Request_list); i := i + 1) | |
{ | |
// v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.xTDP_Request_list[sizeof(v_UIHandler_Requestbuffer.data.choice.xTDP_Requests.xTDP_Request_list)] := | |
// valueof(pl_msg.data.choice.xTDP_Requests.xTDP_Request_list[i]); | |
f_EPTF_UIHandler_requestBuffer_add(valueof(pl_msg.data.choice.xTDP_Requests.xTDP_Request_list[i])); | |
} | |
} | |
} | |
else if (ischosen(pl_msg.data.choice.xTDP_Responses)) | |
{ | |
pl_msg.data.choice.xTDP_Responses.xTDP_Response_list[0].requestId := v_UIHandler_lastRequest; | |
} | |
else if (ischosen(pl_msg.data.choice.xTDP_AddRequests)) | |
{ | |
pl_msg.data.choice.xTDP_AddRequests.xTDP_AddRequest_list[0].requestId := v_UIHandler_lastRequest; | |
} | |
else if (ischosen(pl_msg.data.choice.xTDP_RemoveRequests)) | |
{ | |
pl_msg.data.choice.xTDP_RemoveRequests.xTDP_RemoveRequest_list[0].requestId := v_UIHandler_lastRequest; | |
} | |
else if (ischosen(pl_msg.data.choice.xTDP_LayoutRequest)) | |
{ | |
//pl_msg.data.choice.xTDP_LayoutRequest.requestId := v_UIHandler_lastRequest; | |
} | |
else if (ischosen(pl_msg.data.choice.xTDP_LayoutResponse)) | |
{ | |
//pl_msg.data.choice.xTDP_LayoutResponse.requestId := v_UIHandler_lastRequest; | |
} | |
else if (ischosen(pl_msg.data.choice.xTDP_AuthChallenge) or ischosen(pl_msg.data.choice.xTDP_AuthResponse)) | |
{ | |
} | |
else | |
{ | |
f_EPTF_UIHandler_warning("Unknown XTDP message to send!"); | |
return; | |
} | |
if(tsp_EPTF_UIHandler_bufferedXTDP == 0.0 or ( tsp_EPTF_UIHandler_bufferedXTDP != 0.0 and not ischosen(pl_msg.data.choice.xTDP_Requests))) | |
{ | |
for(var integer i := 0; i < sizeof(v_UIHandler_GUIClientId); i := i + 1) | |
{ | |
var Result vl_result | |
f_EPTF_Transport_send( | |
IPL4, v_UIHandler_GUIClientId[i].clientId, f_EPTF_UIHandler_appendLength_XTDP(XTDP_EncDecFunctions.enc_XTDP_Message(valueof(pl_msg.data))), vl_result, false) | |
} | |
} | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Templates: t_UIHandler_Authmsg | |
// | |
// Purpose: | |
// Send template for authenticating the GUI | |
// | |
// Parameters: | |
// pl_client -- the GUI client | |
// | |
/////////////////////////////////////////////////////////// | |
/*private template ASP_XTDP t_UIHandler_Authmsg(in integer pl_clientid) := { | |
pl_clientid, | |
{omit, | |
{xtdp_AuthChallenge := tsp_EPTF_UIHandler_Authmsg} | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Templates: t_UIHandler_Authresp | |
// | |
// Purpose: | |
// Receinving template for authenticating the GUI | |
// | |
/////////////////////////////////////////////////////////// | |
private template ASP_XTDP t_UIHandler_Authresp := { | |
*, | |
{omit, | |
{xtdp_AuthResponse := ?} | |
} | |
} | |
*/ | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_authclient | |
// | |
// Purpose: | |
// Authenticates the client. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_authclient(in integer pl_clientid) runs on EPTF_UIHandler_Private_CT return boolean{ | |
if (tsp_EPTF_UIHandler_Authmsg=="" or v_EPTF_UIHandler_Authresp == "") { | |
// no authentication needed | |
f_EPTF_UIHandler_setClientAuthenticationSuccessful(pl_clientid); | |
return true; | |
} | |
v_UIHandler_lastRequest := v_UIHandler_lastRequest +1; | |
var integer vl_UIHandler_authResponseReceivedSemaphore := f_EPTF_Semaphore_new(); | |
var ttcn_ericsson_se_protocolModules_xtdp_xtdp.XTDP_Message vl_messageToSend := | |
{ | |
vl_UIHandler_authResponseReceivedSemaphore+1000*v_UIHandler_lastRequest, | |
{xTDP_AuthChallenge := tsp_EPTF_UIHandler_Authmsg} | |
} | |
var Result vl_result | |
f_EPTF_Transport_send(IPL4, pl_clientid, f_EPTF_UIHandler_appendLength_XTDP(XTDP_EncDecFunctions.enc_XTDP_Message(vl_messageToSend)), vl_result, false) | |
if(f_EPTF_Semaphore_waitForUnlock(vl_UIHandler_authResponseReceivedSemaphore, v_authMaxTime)) | |
{ | |
f_EPTF_UIHandler_warning(%definitionId&": Timer timeout! No auth response received!"); | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
return false; | |
} | |
//f_EPTF_Semaphore_lock(v_UIHandler_authResponseReceivedSemaphore); | |
f_EPTF_Semaphore_unlock(v_UIHandler_xtdpReceivedMessageSemaphore_r); | |
if(v_UIHandler_receivedMessage.choice.xTDP_AuthResponse == v_EPTF_UIHandler_Authresp) | |
{ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": Authentication successful for client: "&log2str(pl_clientid)); | |
} | |
f_EPTF_UIHandler_setClientAuthenticationSuccessful(pl_clientid); | |
return true; | |
} | |
else | |
{ | |
f_EPTF_UIHandler_warning("Authentication failed for client: "&log2str(pl_clientid)); | |
return false; | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_headlessmode | |
// | |
// Purpose: | |
// Sets the enviroment for the headless mode | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_headlessmode() runs on EPTF_UIHandler_Private_CT{ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug("******** HeadlessMode*******"); | |
} | |
if (not v_EPTF_UIHandler_servermode){ | |
v_UIHandler_pingcounter := 0; | |
v_UIHandler_prevpingcounter := 0; | |
v_UIHandler_succpingcounter := 0; | |
if(not t_UIHandler_pingtimer.running) { | |
t_UIHandler_pingtimer.start; | |
} | |
} else { | |
f_EPTF_UIHandler_startserverxtdp(); | |
} | |
v_UIHandler_guiConnected := false; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_headlessmodeover | |
// | |
// Purpose: | |
// Restores the enviroment returning back from headless mode | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_headlessmodeover() runs on EPTF_UIHandler_Private_CT{ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug("*********HeadlessModeOVER********") | |
} | |
if (not v_EPTF_UIHandler_servermode){ | |
if (t_UIHandler_pingtimer.running) { | |
t_UIHandler_pingtimer.stop; | |
} | |
v_UIHandler_pingcounter := 0; | |
v_UIHandler_prevpingcounter := 0; | |
v_UIHandler_succpingcounter := 0; | |
var ConnectionId vl_connId; | |
f_EPTF_UIHandler_connectAndInitGui(vl_connId); | |
//In case of v_EPTF_UIHandler_servermode, the f_EPTF_UIHandler_connectAndInitGui | |
//simply returns true | |
//} else { | |
// if (not f_EPTF_UIHandler_connectAndInitGui()){ | |
// f_EPTF_UIHandler_error("Failed to initialize the GUI!"); | |
// } | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_sendSubscAck | |
// | |
// Purpose: | |
// Sends acknowladgement message about a succesfully completed subscription note | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_sendSubscAck( | |
in integer pl_requestId, | |
in integer pl_varIdx, | |
in EPTF_Var_CT pl_sender, | |
in boolean pl_ack := true) | |
runs on EPTF_UIHandler_Private_CT { | |
v_UIHandler_subscriptInProcess := false; | |
var EPTF_UIHandler_WidgetMsg vl_EPTF_CLL_UISubscMgmtMsg := { | |
subscribeAck := { | |
requestId := pl_requestId, | |
varIdx := pl_varIdx}}; | |
EPTF_adminPort_CP.send(vl_EPTF_CLL_UISubscMgmtMsg) to pl_sender | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_sendSubscNAck | |
// | |
// Purpose: | |
// Sends an refusion message about a subscription note | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_sendSubscNAck( | |
in integer pl_requestId, | |
in EPTF_Var_CT pl_sender) | |
runs on EPTF_UIHandler_Private_CT { | |
v_UIHandler_subscriptInProcess := false; | |
var EPTF_UIHandler_WidgetMsg vl_EPTF_CLL_UISubscMgmtMsg := { | |
subscribeNAck := { | |
requestId := pl_requestId, | |
varIdx := -1 | |
} | |
}; | |
EPTF_adminPort_CP.send(vl_EPTF_CLL_UISubscMgmtMsg) to pl_sender; | |
} | |
/////////////////////////////////////////////////////////// | |
// Group: EPTF_SubscriptionAdministrationFunctions | |
/////////////////////////////////////////////////////////// | |
group EPTF_SubscriptionAdministrationFunctions{ | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_newSubscription | |
// | |
// Purpose: | |
// Appends an EPTF_UIHandler_OpenSubscription record to the <EPTF_UIHandler_OpenSubscriptions> list. | |
// | |
// Parameters: | |
// pl_subscription - *in* *EPTF_UIHandler_OpenSubscription* - The record to append. | |
// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_newSubscription(in EPTF_UIHandler_OpenSubscription pl_subscription) | |
runs on EPTF_UIHandler_Private_CT | |
{ | |
var integer vl_newIdx := sizeof(v_UIHandler_openSubscriptions); | |
v_UIHandler_openSubscriptions[vl_newIdx] := pl_subscription; | |
f_EPTF_UIHandler_addSubscription(pl_subscription.varIdx, vl_newIdx); | |
if (pl_subscription.providedParamName != "") { | |
f_EPTF_str2int_HashMap_Insert(v_UIHandler_subscriptionHashMapIdVar, pl_subscription.providedParamName, pl_subscription.varIdx); | |
} | |
if (pl_subscription.widgetId != "") { | |
f_EPTF_str2int_HashMap_Insert(v_UIHandler_subscriptionHashMapId, pl_subscription.widgetId, vl_newIdx); | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_getSubscriptionsByVarIdx | |
// | |
// Purpose: | |
// Retrieves a list of open subscriptions that are affected by the specified variable. | |
// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_getSubscriptionsByVarIdx(in integer pl_varIdx, out EPTF_UIHandler_OpenSubscriptions pl_ret) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var EPTF_IntegerList vl_subs := f_EPTF_UIHandler_getSubscriptions(pl_varIdx); | |
pl_ret := {}; | |
for(var integer vl_i := 0; vl_i < sizeof(vl_subs); vl_i := vl_i+1){ | |
pl_ret[sizeof(pl_ret)] := v_UIHandler_openSubscriptions[vl_subs[vl_i]]; | |
} | |
return sizeof(pl_ret) > 0; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_getSubscriptionIdxByWidgetId | |
// | |
// Return Value: | |
// The index of the open subscription that contains the specified widgetId or -1. | |
// | |
/////////////////////////////////////////////////////////// | |
friend function f_EPTF_UIHandler_getSubscriptionIdxByWidgetId(in EPTF_UIHandler_WidgetIdString pl_widgetId) | |
runs on EPTF_UIHandler_Private_CT | |
return integer{ | |
if("" == pl_widgetId){ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": No subscription belongs to empty ID!"); | |
} | |
return -1; | |
} | |
// find id in subscription hashmap | |
var integer vl_idx; | |
if (f_EPTF_str2int_HashMap_Find(v_UIHandler_subscriptionHashMapId, pl_widgetId, vl_idx)) { | |
return vl_idx; | |
} | |
return -1; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_getVarIdxByProvidedVarName | |
// | |
// Return Value: | |
// The index of the open subscription that contains the | |
// specified client variable name. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_getVarIdxByProvidedVarName(in charstring pl_varName) | |
runs on EPTF_UIHandler_Private_CT | |
return integer{ | |
if("" == pl_varName){ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": No subscription belongs to empty variable name!"); | |
} | |
return -1; | |
} | |
// find id in subscription hashmap | |
var integer vl_idx; | |
if (f_EPTF_str2int_HashMap_Find(v_UIHandler_subscriptionHashMapIdVar, pl_varName, vl_idx)) { | |
return vl_idx; | |
} | |
return -1; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addSubscription | |
// | |
// Purpose: | |
// Adds a subscription item to a variable | |
// | |
// Parameters: | |
// pl_idx - *in* *integer* - the idx of the EPTF_Var | |
// pl_subsIdx - *in* *integer* - subscription identifier index | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// - | |
// | |
// Detailed Comments: | |
// - | |
// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_addSubscription(in integer pl_idx, in integer pl_subsIdx) | |
runs on EPTF_UIHandler_Private_CT | |
{ | |
if(sizeof(v_UIHandler_subscriptions) <= pl_idx or not isbound(v_UIHandler_subscriptions[pl_idx])) { | |
v_UIHandler_subscriptions[pl_idx] := {}; | |
} | |
v_UIHandler_subscriptions[pl_idx][sizeof(v_UIHandler_subscriptions[pl_idx])] := pl_subsIdx; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeSubscription | |
// | |
// Purpose: | |
// Removes a subscription item from a variable | |
// | |
// Parameters: | |
// pl_idx - *in* *integer* - the idx of the EPTF_Var | |
// pl_subsIdx - *in* *integer* - subscription identifier index | |
// | |
// Return Value: | |
// - | |
// | |
// Errors: | |
// - | |
// | |
// Detailed Comments: | |
// - | |
// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_removeSubscription(in integer pl_idx, in integer pl_subsIdx) | |
runs on EPTF_UIHandler_Private_CT | |
{ | |
f_EPTF_Base_assert(%definitionId&": not a local subscription.", | |
sizeof(v_UIHandler_subscriptions) > pl_idx and isbound(v_UIHandler_subscriptions[pl_idx])); | |
var integer vl_subIdx := -1; | |
for (var integer i := 0; i < sizeof(v_UIHandler_subscriptions[pl_idx]); i := i + 1) | |
{ | |
if (v_UIHandler_subscriptions[pl_idx][i] == pl_subsIdx) | |
{ | |
vl_subIdx := i; | |
break; | |
} | |
} | |
if (vl_subIdx != -1) | |
{ | |
var EPTF_IntegerList vl_newSubs := {}; | |
for (var integer i := 0; i < sizeof(v_UIHandler_subscriptions[pl_idx]); i := i + 1) | |
{ | |
if (vl_subIdx != i) { vl_newSubs[sizeof(vl_newSubs)] := v_UIHandler_subscriptions[pl_idx][i]; } | |
} | |
v_UIHandler_subscriptions[pl_idx] := vl_newSubs; | |
return; | |
} | |
f_EPTF_UIHandler_warning(log2str("The variable: ", f_EPTF_Var_getName(pl_idx), " has no subscription: ", pl_subsIdx)); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_getSubscriptions | |
// | |
// Purpose: | |
// Gets the subscription indices of a variable | |
// | |
// Parameters: | |
// pl_idx - *in* *integer* - the idx of the EPTF_Var | |
// | |
// Return Value: | |
// <EPTF_IntegerList> - the list of subscripton indices of the variable | |
// | |
// Errors: | |
// - | |
// | |
// Detailed Comments: | |
// - | |
// | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_getSubscriptions(in integer pl_idx) | |
runs on EPTF_UIHandler_Private_CT return EPTF_IntegerList | |
{ | |
if (sizeof(v_UIHandler_subscriptions) <= pl_idx or | |
not isbound(v_UIHandler_subscriptions[pl_idx])) { | |
return {}; | |
} | |
return v_UIHandler_subscriptions[pl_idx]; | |
} | |
} //EPTF_SubscriptionAdministrationFunctions group | |
/////////////////////////////////////////////////////////// | |
// Group: EPTF_WidgetAdministrationFunctions | |
/////////////////////////////////////////////////////////// | |
group EPTF_WidgetAdministrationFunctions{ | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_widgetTypeFromId | |
// | |
// Purpose: | |
// Gets the type of a widget | |
// Detailed Comments: | |
// There are two main cases: | |
// the widget ID describes a cell of a tree in form "name of the tree".[row].[column], or | |
// the ID is the widget's own ID | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_widgetTypeFromId( | |
in EPTF_UIHandler_WidgetIdString pl_id, | |
inout EPTF_UIHandler_OpenSubscription pl_subs) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
// cehck if id refers a table cell in format "treeId.[row].[col]" | |
var integer vl_row, vl_col; | |
var EPTF_UIHandler_WidgetIdString vl_treeId; | |
if (f_EPTF_UIHandler_isTreeCellIdFormat(pl_id, vl_treeId, vl_row, vl_col)) { | |
var EPTF_UIHandler_GuiItemRec widgetRec; | |
if(f_EPTF_UIHandler_getWidgetRec(vl_treeId, widgetRec)){ | |
if(vl_col <= sizeof(widgetRec.widgetData.treeData.columns)){ | |
pl_subs.widgetType := wtTreecell; | |
pl_subs.widgetDataType := v_UIHandler_guiItemList[widgetRec.widgetData.treeData.columns[vl_col]].widgetDataType; | |
return true; | |
} | |
} | |
}else{ | |
var EPTF_UIHandler_GuiItemRec widgetRec; | |
if(f_EPTF_UIHandler_getWidgetRec(pl_id, widgetRec)){ | |
pl_subs.widgetType := widgetRec.widgetType; | |
//The cell also contains widgetDataType | |
pl_subs.widgetDataType := widgetRec.widgetDataType; | |
return true; | |
} | |
} | |
return false; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_checkSubscriptCompatibility | |
// Purpose: | |
// Checks whether the subscriptable variable and the widget | |
// are compatible | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_checkSubscriptCompatibility( | |
in EPTF_UIHandler_WidgetIdString pl_widgetid, | |
in integer pl_varIdx, | |
in EPTF_Var_DirectContent pl_currentContent := {unknownVal:={omit}}) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var integer vl_index := f_EPTF_UIHandler_widgetRecIndex(pl_widgetid); | |
if (vl_index==-1) { | |
f_EPTF_UIHandler_error("The specified '"&pl_widgetid&"' widget can not be connected to variable["&f_EPTF_Var_getName(pl_varIdx)&"]: widget not found!"); | |
return false; | |
} | |
var EPTF_Var_DirectContent vl_currentContent := pl_currentContent; | |
var boolean vl_retval; | |
var boolean vl_checkReverse := false; | |
if (ischosen(vl_currentContent.unknownVal)) { | |
f_EPTF_Var_getContent(pl_varIdx,vl_currentContent); | |
} | |
select(v_UIHandler_guiItemList[vl_index].widgetType){ | |
case(wtWindow, // nothing to check NOW | |
wtTabbox, | |
wtTabs, | |
wtTab, | |
wtTabpanels, | |
wtTabpanel, | |
wtTabpages, | |
wtTabpage, | |
wtTree, | |
wtTreecols, | |
wtTreecol, | |
wtTreechildren, | |
wtTreeitem, | |
wtTreerow, | |
wtHbox, | |
wtLabel, | |
wtSpacer, | |
wtChart, | |
wtTraceList, | |
wtToolbar, | |
wtToolbarbuttons, | |
wtSeparator, | |
wtListbox, | |
wtListitem, | |
wtNumericalwidget, | |
wtMenulist, | |
wtMenuitem, | |
wtDistributionchart, | |
wtIntervallimits, | |
wtValuelist, | |
wtImage, | |
wtUnknown){ | |
vl_retval := true; | |
} | |
case(wtTreecell){ | |
vl_checkReverse := true; | |
select(v_UIHandler_guiItemList[vl_index].widgetDataType){ | |
case(checkBox){vl_retval := ischosen(vl_currentContent.boolVal)} | |
case(toggleButton){vl_retval := ischosen(vl_currentContent.boolVal)} | |
case(floatField){vl_retval := ischosen(vl_currentContent.floatVal)} | |
case(pushButton, integerField){vl_retval := ischosen(vl_currentContent.intVal)} | |
case(string){ vl_retval := ischosen(vl_currentContent.charstringVal) | |
or ischosen(vl_currentContent.floatVal) | |
or ischosen(vl_currentContent.intVal) | |
/* string forever */ | |
or ischosen(vl_currentContent.bitstringVal) or ischosen(vl_currentContent.hexstringVal) or ischosen(vl_currentContent.octetstringVal) | |
or ischosen(vl_currentContent.boolVal) | |
or ischosen(vl_currentContent.statusLEDVal) | |
or ischosen(vl_currentContent.integerlistVal) or ischosen(vl_currentContent.floatlistVal) or ischosen(vl_currentContent.charstringlistVal) | |
} | |
case(statusLED){vl_retval := ischosen(vl_currentContent.statusLEDVal) | |
/* its not equal, because type without are make errror on runtime gui if returned with text, | |
text but better if this equal this time just no returned text on request | |
and (ispresent(vl_currentContent.statusLEDVal.text)==false or vl_currentContent.statusLEDVal.text == "") */; } | |
case(statusLEDWithText){vl_retval := ischosen(vl_currentContent.statusLEDVal)} | |
case else { } | |
} | |
} | |
case (wtButton){ | |
vl_retval := ischosen(vl_currentContent.intVal); | |
} | |
case (wtPushbutton){ | |
vl_retval := ischosen(vl_currentContent.intVal); | |
} | |
case(wtTextbox){vl_retval := true; } // string forever | |
case(wtHtmlcode){vl_retval := true; } // string forever | |
case(wtTrace){ | |
vl_retval := (ischosen(vl_currentContent.floatVal) or ischosen(vl_currentContent.intVal)); | |
} | |
case (wtToolbarbutton, wtTogglebutton){ | |
vl_retval := ischosen(vl_currentContent.boolVal); | |
} | |
case else { | |
vl_retval := true; // all other are true now | |
} | |
} | |
if(isbound(vl_retval)==false) { | |
f_EPTF_UIHandler_error("The specified '"&pl_widgetid&"' widget with data("&log2str(v_UIHandler_guiItemList[vl_index])&") not match to variable["&f_EPTF_Var_getName(pl_varIdx)&"]: type incompatibility!"); | |
} else if(vl_retval == false) { | |
f_EPTF_UIHandler_error("The specified '"&pl_widgetid&"' widget with data("&log2str(v_UIHandler_guiItemList[vl_index])&") can not be connected to variable["&f_EPTF_Var_getName(pl_varIdx)&"]: type incompatibility!"); | |
} | |
else { | |
if(vl_checkReverse == true and ispresent( v_UIHandler_guiItemList[vl_index].widgetDataType)) { | |
vl_retval := f_EPTF_UIHandler_checkVariableCompatibility(vl_currentContent, v_UIHandler_guiItemList[vl_index].widgetDataType); | |
} | |
if(vl_retval == false) { | |
f_EPTF_UIHandler_error("The specified variable["&f_EPTF_Var_getName(pl_varIdx)&"] can not be connected to specified '"&pl_widgetid&"' widget with data("&log2str(v_UIHandler_guiItemList[vl_index])&"): type incompatibility!"); | |
} | |
} | |
return vl_retval; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_checkVariableCompatibility | |
// Purpose: | |
// Checks whether the the requeted variable and the widget | |
// type are compatible | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_checkVariableCompatibility( | |
in EPTF_Var_DirectContent pl_currentContent, | |
in Widgettype pl_currentwidgetDataType) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var boolean vl_retval := false; | |
if(ischosen(pl_currentContent.intVal)) { | |
vl_retval := (pl_currentwidgetDataType == integerField) | |
or (pl_currentwidgetDataType == pushButton) | |
or (pl_currentwidgetDataType == trace) | |
or (pl_currentwidgetDataType == string); // string forever | |
} | |
else | |
if(ischosen(pl_currentContent.floatVal)) { | |
vl_retval := (pl_currentwidgetDataType == floatField) | |
or (pl_currentwidgetDataType == string); // string forever | |
} | |
else | |
if(ischosen(pl_currentContent.charstringVal)) { | |
vl_retval := (pl_currentwidgetDataType == string) | |
or (pl_currentwidgetDataType == image); | |
} | |
else | |
if(ischosen(pl_currentContent.bitstringVal) or ischosen(pl_currentContent.hexstringVal) or ischosen(pl_currentContent.octetstringVal)) { | |
vl_retval := (pl_currentwidgetDataType == string); | |
} | |
else | |
if(ischosen(pl_currentContent.boolVal)) { | |
vl_retval := (pl_currentwidgetDataType == checkBox) | |
or (pl_currentwidgetDataType == toggleButton) | |
or (pl_currentwidgetDataType == string); // string forever | |
} | |
else | |
if(ischosen(pl_currentContent.statusLEDVal)) { | |
vl_retval := (pl_currentwidgetDataType == statusLED) | |
or (pl_currentwidgetDataType == statusLEDWithText) | |
or (pl_currentwidgetDataType == string); // string forever | |
} | |
else | |
if(ischosen(pl_currentContent.integerlistVal) or ischosen(pl_currentContent.floatlistVal) or ischosen(pl_currentContent.charstringlistVal)) { | |
vl_retval := (pl_currentwidgetDataType == valueList) | |
or (pl_currentwidgetDataType == string); // string forever | |
} | |
// If not matched | |
if(vl_retval == false) { | |
vl_retval := (pl_currentwidgetDataType == image) | |
or (pl_currentwidgetDataType == none_); | |
} | |
return vl_retval; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_handleSubscriptNote | |
// Purpose: | |
// Handles te subscription note message | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_handleSubscriptNote( | |
in EPTF_UIHandler_SubscribeNoteMsg pl_msg, | |
in EPTF_Var_CT pl_sender) | |
runs on EPTF_UIHandler_Private_CT { | |
v_UIHandler_subscriptInProcess := true; | |
var EPTF_UIHandler_OpenSubscription vl_subs := c_UIHandler_defOpenSubscription; | |
var integer vl_varIdx := -1; | |
if(ispresent(pl_msg.destParamName) and "" != pl_msg.destParamName){ | |
//we must create a new variable and subscribe it to a provided param | |
//check if it already exists | |
if(not f_EPTF_Var_checkName(pl_msg.destParamName,vl_varIdx)) // i.e. vl_varIdx != -1 | |
{ | |
f_EPTF_UIHandler_warning("CLL_UIHandler: the destination variable already exists: " & pl_msg.destParamName); | |
f_EPTF_UIHandler_sendSubscNAck(pl_msg.messageId, pl_sender); | |
return; | |
} | |
//log("DEBUG: ","------- subscribeRemote ------- ",pl_msg.providedParamName); | |
//In case of error the remote variable stops the test | |
f_EPTF_Var_subscribeRemote( | |
pl_msg.remoteCompRef, | |
pl_msg.providedParamName, | |
pl_msg.subsMode, | |
vl_varIdx, | |
pl_msg.destParamName, | |
pl_msg.refreshRate); | |
f_EPTF_Var_addPostProcFn(vl_varIdx, {refers(f_EPTF_UIHandler_refreshVar),{}}); | |
// FIXME: test | |
// FIXME: This should be put back if old gui build using SubsCanAdjust is working: | |
//f_EPTF_Var_addSubsCanAdjustNotifyFn(vl_varIdx, {refers(f_EPTF_UIHandler_updateDisableStateByVarIdx), {}}); | |
}else{ | |
//There is no destParamName, so it's an ealrier subscription | |
//Get the index of the variable | |
vl_varIdx := f_EPTF_UIHandler_getVarIdxByProvidedVarName(pl_msg.providedParamName); | |
if(-1 == vl_varIdx){ | |
f_EPTF_UIHandler_warning("CLL_UIHandler: there is no subscription to the variable: " & pl_msg.providedParamName); | |
f_EPTF_UIHandler_sendSubscNAck(pl_msg.messageId, pl_sender); | |
return; | |
} | |
} | |
if(ispresent(pl_msg.widgetId)){ | |
if (f_EPTF_UIHandler_Config_connectToWidget(pl_msg.widgetId,vl_varIdx,pl_msg.remoteCompRef,pl_msg.providedParamName)) { | |
// FIXME: This should be put back if old gui build using SubsCanAdjust is working: | |
//f_EPTF_UIHandler_updateDisableStateByVarIdx(vl_varIdx, {}); | |
f_EPTF_UIHandler_sendSubscAck(pl_msg.messageId, vl_varIdx, pl_sender); | |
} else { | |
f_EPTF_UIHandler_sendSubscNAck(pl_msg.messageId, pl_sender); | |
} | |
return; | |
} else { | |
vl_subs.widgetId := ""; | |
} | |
vl_subs.provider := pl_msg.remoteCompRef; | |
vl_subs.varIdx := vl_varIdx; | |
vl_subs.providedParamName:=pl_msg.providedParamName; | |
//FIXME!!!Check compatibility | |
f_EPTF_UIHandler_newSubscription(vl_subs); | |
f_EPTF_UIHandler_sendSubscAck(pl_msg.messageId, vl_varIdx, pl_sender); | |
if(ispresent(pl_msg.widgetId)){ | |
f_EPTF_UIHandler_refreshWidget(vl_subs, true); | |
// FIXME: This should be put back if old gui build using SubsCanAdjust is working: | |
//f_EPTF_UIHandler_updateDisableStateByVarIdx(vl_varIdx, {}); | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_refreshVar | |
// | |
// Purpose: | |
// Postproc. The component refreshes the content of the GUI | |
// when the content of the variable changes | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_refreshVar(in integer pl_idx, in EPTF_IntegerList pl_argList) | |
runs on EPTF_UIHandler_Private_CT { | |
if (not v_UIHandler_initialized) { | |
return; | |
} | |
var EPTF_UIHandler_OpenSubscriptions vl_subsList; | |
if (not f_EPTF_UIHandler_getSubscriptionsByVarIdx(pl_idx, vl_subsList)){ | |
f_EPTF_UIHandler_warning("The subscriptionlist is empty for this variable!"); | |
} | |
for(var integer vl_i := 0; vl_i < sizeof(vl_subsList); vl_i := vl_i+1){ | |
//Put the received value to the screen. It can differ from the typed value. | |
//log("DEBUG: ","---- postproc - ",vl_subsList[vl_i].widgetId, " - ", v_EPTF_Vars[vl_subsList[vl_i].varIdx].content.direct); | |
f_EPTF_UIHandler_refreshWidget(vl_subsList[vl_i]); | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeWidgetFromSubscription | |
// Purpose: | |
// Clears the widgetId member of the open subscription associated | |
// with the specified widget. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_removeWidgetFromSubscription(in EPTF_UIHandler_WidgetIdString pl_widgetId) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var integer vl_idx := f_EPTF_UIHandler_getSubscriptionIdxByWidgetId(pl_widgetId); | |
if(-1 == vl_idx){ | |
return false; | |
} | |
f_EPTF_str2int_HashMap_Erase(v_UIHandler_subscriptionHashMapId, pl_widgetId); | |
v_UIHandler_openSubscriptions[vl_idx].widgetId := ""; | |
return true; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeIdFromIdList | |
// Purpose: | |
// Removes an integer from an integer list. | |
// | |
// Return Value: | |
// A new list of integers without gaps and the specified integer. | |
// | |
// Detailed Comments: | |
// The function handles only unique integers. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_removeIdFromIdList(in EPTF_IntegerList pl_in, in integer pl_idx) | |
return EPTF_IntegerList{ | |
var EPTF_IntegerList vl_ret := {}; | |
var integer vl_i := 0; | |
while(vl_i < sizeof(pl_in)){ | |
if(pl_in[vl_i] != pl_idx){ | |
vl_ret[sizeof(vl_ret)] := pl_in[vl_i]; | |
} | |
vl_i := vl_i + 1; | |
} | |
return vl_ret; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addIdx2IdxList | |
// Purpose: | |
// Simply append an integer to an integer list. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_addIdx2IdxList(inout EPTF_IntegerList pl_in, in integer pl_idx){ | |
pl_in[sizeof(pl_in)] := pl_idx; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_insertIdx2IdxList | |
// Purpose: | |
// Insert a new integer into an integer list in a specific index | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_insertIdx2IdxList(inout EPTF_IntegerList pl_in, in integer pl_idx, in integer pl_value){ | |
for ( var integer i := sizeof(pl_in)-1; i >= pl_idx ; i := i-1 ) { | |
pl_in[i+1] := pl_in[i]; | |
} | |
pl_in[pl_idx] := pl_value; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_IdxListContains | |
// Return Value: | |
// True if the integerlist contains the specified value. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_IdxListContains(in EPTF_IntegerList pl_in, in integer pl_idx) | |
return boolean{ | |
for(var integer vl_i := 0; vl_i < sizeof(pl_in); vl_i := vl_i + 1){ | |
if(pl_in[vl_i] == pl_idx){return true;} | |
} | |
return false; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_parentColOfCell | |
// Purpose: | |
// Retrieves the GUI index of the column into which the cell is placed | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_parentColOfCell(in integer pl_parent) | |
runs on EPTF_UIHandler_Private_CT | |
return integer{ | |
if(-1 == pl_parent){return -1;} | |
var integer vl_i := pl_parent; | |
while(vl_i != -1 and v_UIHandler_guiItemList[vl_i].widgetType != wtTreecol){ | |
vl_i := v_UIHandler_guiItemList[vl_i].parentIdx; | |
} | |
if(vl_i != -1 and v_UIHandler_guiItemList[vl_i].widgetType == wtTreecol){ | |
return vl_i; | |
} | |
return -1; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addWidgetRec | |
// Purpose: | |
// Adds the specified record about a widget to the list | |
// of the widgets. | |
// | |
// Return Value: | |
// The index of the new record if succes, or -1 | |
// | |
// Detailed Comments: | |
// If there is already a widget with the same id with the | |
// same type under the same parent, the function returns | |
// the index of the previous widget, and sets the pl_widgetExists to true. | |
// If pl_indexInParent parameter is given (not -1), widgetrec is placed | |
// to that position in parents' childrenlist. | |
// This is needed for tree column insertion. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_addWidgetRec( | |
in EPTF_UIHandler_GuiItemRec pl_widgetRec, | |
inout boolean pl_widgetExists/*, | |
in integer pl_indexInParent := -1*/) | |
runs on EPTF_UIHandler_Private_CT | |
return integer{ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": "&log2str(pl_widgetRec)); | |
} | |
pl_widgetExists := false; | |
//Checking the index of the parent item. Less than 0 is valid for the main window. | |
if(pl_widgetRec.parentIdx> sizeof(v_UIHandler_guiItemList) or | |
(pl_widgetRec.parentIdx < 0 and (pl_widgetRec.widgetType != wtWindow))){ | |
f_EPTF_UIHandler_warning("Invalid parent index for the widget "&pl_widgetRec.id&"."); | |
return -1; | |
} | |
//If the parent widget from the pl_widgetRec.parentIdx is a tabpages, then pl_widgetRec.widgetType can only be a tabpage, | |
//else warning and return -1 | |
if( ((pl_widgetRec.parentIdx > -1) and pl_widgetRec.widgetType != wtTabpage and pl_widgetRec.widgetType != wtMetaIterator) and v_UIHandler_guiItemList[pl_widgetRec.parentIdx].widgetType == wtTabpages){ | |
f_EPTF_UIHandler_warning("Under a tabpages widget only widgets with type tabpage is allowed: "&pl_widgetRec.id&"."); | |
return -1; | |
} | |
var boolean vl_xuldisabled := false; | |
if(ispresent(pl_widgetRec.xuldisabled)){ | |
vl_xuldisabled := pl_widgetRec.xuldisabled; | |
} | |
var EPTF_UIHandler_GuiItemRec vl_newRec := { | |
id := pl_widgetRec.id, | |
widgetType := pl_widgetRec.widgetType, | |
widgetDataType := pl_widgetRec.widgetDataType, | |
parentIdx := pl_widgetRec.parentIdx, | |
children := {}, | |
widgetData := pl_widgetRec.widgetData, | |
XULformat := pl_widgetRec.XULformat, | |
xuldisabled := vl_xuldisabled | |
}; | |
//Checking ID | |
var integer vl_idx; | |
var boolean vl_isexisting := (pl_widgetRec.id != "" and f_EPTF_str2int_HashMap_Find(v_UIHandler_widgetHashMapId, pl_widgetRec.id, vl_idx)); | |
var integer vl_prevIdx := -1; | |
if(pl_widgetRec.XULformat != omit and ischosen(pl_widgetRec.XULformat.treecell)){ | |
var Treecell vl_treecell := pl_widgetRec.XULformat.treecell; | |
vl_treecell.id := omit; | |
vl_prevIdx := f_EPTF_UIHandler_widgetRecIndex(pl_widgetRec.id, f_EPTF_UIHandler_deleteChildrenFromTreecell(vl_treecell)); | |
} else { | |
vl_prevIdx := f_EPTF_UIHandler_widgetRecIndex(pl_widgetRec.id); | |
} | |
if(vl_isexisting == true){ // old -1 != vl_prevIdx | |
f_EPTF_UIHandler_setWidgetOriginalDisabled(vl_prevIdx); // Set original [xul] disabled state | |
if(v_UIHandler_customGUIProcess){ | |
f_EPTF_UIHandler_error(%definitionId&": Duplicate widget ID: "& pl_widgetRec.id&"\nThe GUI descriptor is: "&log2str("v_UIHandler_widgetslist")); | |
}else{ | |
var integer vl_row, vl_col; | |
var EPTF_UIHandler_WidgetIdString vl_treeId; | |
if (not f_EPTF_UIHandler_isTreeCellIdFormat(pl_widgetRec.id, vl_treeId, vl_row, vl_col)){ | |
pl_widgetExists := true; | |
} | |
if(v_UIHandler_guiItemList[vl_prevIdx].widgetType != pl_widgetRec.widgetType or | |
v_UIHandler_guiItemList[vl_prevIdx].parentIdx != pl_widgetRec.parentIdx){ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": Duplicate widget ID: "& pl_widgetRec.id); | |
} | |
return -1; | |
}else{ | |
//There is a similar widget | |
return vl_prevIdx; | |
} | |
} | |
} | |
if(-1 == vl_prevIdx){ | |
var integer vl_newIdx := sizeof(v_UIHandler_guiItemList); | |
v_UIHandler_guiItemList[vl_newIdx] := vl_newRec; | |
if(vl_newRec.widgetType != wtMetaIterator) { | |
if( v_UIHandler_actualParentIdxIsFilled == false) { | |
//window's parent is -1, but getNonMeta gives 0 back, because window has 0 id | |
if(vl_newRec.widgetType != wtWindow){ | |
v_UIHandler_actualParentIdx := f_EPTF_UIHAndler_getNotMetaiteratorParentIdx(vl_newIdx); | |
} else { | |
v_UIHandler_actualParentIdx := pl_widgetRec.parentIdx; | |
} | |
v_UIHandler_actualParentIdxIsFilled := true | |
v_UIHandler_widgetIdxList[sizeof(v_UIHandler_widgetIdxList)] := vl_newIdx; | |
} else if( v_UIHandler_actualParentIdx == f_EPTF_UIHAndler_getNotMetaiteratorParentIdx(vl_newIdx) or | |
/*because tabpagelist: put all tabpagelist element, if same it has parent as the first tabpage element*/ | |
( v_UIHandler_actualParentIdx != -1 and vl_newRec.widgetType == wtTabpage and | |
f_EPTF_UIHAndler_getNotMetaiteratorParentIdx(v_UIHandler_guiItemList[vl_newIdx].parentIdx) == | |
f_EPTF_UIHAndler_getNotMetaiteratorParentIdx(v_UIHandler_guiItemList[v_UIHandler_actualParentIdx].parentIdx) | |
) | |
) { | |
v_UIHandler_widgetIdxList[sizeof(v_UIHandler_widgetIdxList)] := vl_newIdx; | |
} | |
} | |
// add widget id to the widgetId map | |
if (vl_newRec.id != "") { | |
f_EPTF_str2int_HashMap_Insert(v_UIHandler_widgetHashMapId, vl_newRec.id, vl_newIdx); | |
} | |
//Add to its parent's childrenlist | |
if(-1 != vl_newRec.parentIdx){ | |
//if (pl_indexInParent <0) { | |
v_UIHandler_guiItemList[vl_newRec.parentIdx].children[sizeof(v_UIHandler_guiItemList[vl_newRec.parentIdx].children)] := vl_newIdx; | |
//} | |
//else { | |
// f_EPTF_UIHandler_insertIdx2IdxList(v_UIHandler_guiItemList[vl_newRec.parentIdx].children, pl_indexInParent, vl_newIdx); | |
// } | |
} | |
f_EPTF_UIHandler_setWidgetOriginalDisabled(vl_newIdx); // Set original [xul] disabled state | |
return vl_newIdx; | |
} else { | |
return vl_prevIdx; | |
} | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeWidgetRecByName | |
// Purpose: | |
// Removes the specified record about a widget from the list | |
// of the widgets. See <f_EPTF_UIHandler_removeWidgetRecByIdx>. | |
// | |
// Return Value: | |
// True if succes, false otherwise. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_removeWidgetRecByName(in EPTF_UIHandler_WidgetIdString pl_widgetId) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var integer vl_recIdx := f_EPTF_UIHandler_widgetRecIndex(pl_widgetId); | |
if(-1 == vl_recIdx){ | |
return false; | |
} | |
return f_EPTF_UIHandler_removeWidgetRecByIdx(vl_recIdx); | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_removeWidgetRecByIdx | |
// Purpose: | |
// Removes the specified record about a widget from the list | |
// of the widgets. | |
// | |
// Return Value: | |
// True if succes, false otherwise. | |
// | |
// Detailed Comments: | |
// Removes also the children of the widget from the list. | |
// Removes the index of the widget too from the children's list | |
// of the parent of the specified widget. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_removeWidgetRecByIdx(in integer pl_recIdx) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean { | |
f_EPTF_Base_assert(%definitionId&": Boundary check failed - invalid widget record index", | |
pl_recIdx >= 0 and pl_recIdx < sizeof(v_UIHandler_guiItemList)); | |
var boolean vl_ret := true; | |
//Check if there was an open connection | |
var integer vl_connIdx := f_EPTF_UIHandler_getSubscriptionIdxByWidgetId(v_UIHandler_guiItemList[pl_recIdx].id); | |
if(-1 != vl_connIdx){ | |
f_EPTF_str2int_HashMap_Erase(v_UIHandler_subscriptionHashMapId, v_UIHandler_openSubscriptions[vl_connIdx].widgetId); | |
v_UIHandler_openSubscriptions[vl_connIdx].widgetId := ""; | |
} | |
//parse children | |
var EPTF_IntegerList vl_children := v_UIHandler_guiItemList[pl_recIdx].children; | |
for(var integer vl_i := 0; vl_i < sizeof(vl_children); vl_i := vl_i + 1){ | |
if(vl_children[vl_i]> -1){ | |
vl_ret := vl_ret and f_EPTF_UIHandler_removeWidgetRecByIdx(vl_children[vl_i]); | |
} | |
} | |
//remove from the childlist of its parent | |
if(-1 != v_UIHandler_guiItemList[pl_recIdx].parentIdx){ | |
v_UIHandler_guiItemList[v_UIHandler_guiItemList[pl_recIdx].parentIdx].children := | |
f_EPTF_UIHandler_removeIdFromIdList(v_UIHandler_guiItemList[v_UIHandler_guiItemList[pl_recIdx].parentIdx].children,pl_recIdx); | |
} | |
// delete widgetId from hashmap | |
if (v_UIHandler_guiItemList[pl_recIdx].id != "") { | |
f_EPTF_str2int_HashMap_Erase(v_UIHandler_widgetHashMapId, v_UIHandler_guiItemList[pl_recIdx].id); | |
} | |
//clear record | |
v_UIHandler_guiItemList[pl_recIdx] := c_UIHandler_emptyGUIItem; | |
return vl_ret; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_widgetRecIndex | |
// Return Value: | |
// The index of the <EPTF_UIHandler_GuiItemRec> that describes the | |
// specified widget, or -1. | |
/////////////////////////////////////////////////////////// | |
friend function f_EPTF_UIHandler_widgetRecIndex( | |
in EPTF_UIHandler_WidgetIdString pl_id, //The ID of the widget | |
in Treecell pl_treecell := {omit, omit, omit, omit, omit, omit, omit, omit} | |
) | |
runs on EPTF_UIHandler_Private_CT | |
return integer{ | |
var integer vl_idx := 0; | |
// check if empty id | |
if("" == pl_id){ | |
if(c_EPTF_Common_debugSwitch and f_EPTF_UIHandler_debugEnabled()){ | |
f_EPTF_UIHandler_debug(%definitionId&": widgetRecIndex with empty ID!"); | |
} | |
return -1; | |
} | |
// try to find id in internal database | |
if (f_EPTF_str2int_HashMap_Find(v_UIHandler_widgetHashMapId, pl_id, vl_idx)) { | |
return vl_idx; | |
} | |
// // check if id refers a table cell in format "treeId.[row].[col]" | |
// var integer vl_row, vl_col; | |
// var EPTF_UIHandler_WidgetIdString vl_treeId; | |
// if (f_EPTF_UIHandler_isTreeCellIdFormat(pl_id, vl_treeId, vl_row, vl_col)) { | |
// if (f_EPTF_str2int_HashMap_Find(v_UIHandler_widgetHashMapId, vl_treeId, vl_idx) and | |
// v_UIHandler_guiItemList[vl_idx].widgetType == wtTree) | |
// { | |
// var integer vl_colNum := sizeof(v_UIHandler_guiItemList[vl_idx].widgetData.treeData.columns); | |
// if (vl_col < vl_colNum) { | |
// var EPTF_UIHandler_GuiItemRec vl_newRec := { | |
// pl_id, | |
// wtTreecell, | |
// v_UIHandler_guiItemList[v_UIHandler_guiItemList[vl_idx].widgetData.treeData.columns[vl_col]].widgetDataType, | |
// vl_idx, | |
// {}, | |
// {cellData := {v_UIHandler_guiItemList[vl_idx].widgetData.treeData.columns[vl_col], omit}}, | |
// { treecell := pl_treecell}}; | |
// var integer vl_newIdx := sizeof(v_UIHandler_guiItemList); | |
// v_UIHandler_guiItemList[vl_newIdx] := vl_newRec; | |
// if (vl_newRec.id != "") { | |
// f_EPTF_str2int_HashMap_Insert(v_UIHandler_widgetHashMapId, vl_newRec.id, vl_newIdx); | |
// } | |
// f_EPTF_UIHandler_setWidgetOriginalDisabled(vl_newIdx); // Set original [xul] disabled state | |
// //Add to its parent's childrenlist | |
// if(-1 != vl_newRec.parentIdx){ | |
// v_UIHandler_guiItemList[vl_newRec.parentIdx].children[sizeof(v_UIHandler_guiItemList[vl_newRec.parentIdx].children)] := vl_newIdx; | |
// } | |
// return vl_newIdx; | |
// } | |
// } | |
// } | |
return -1; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_isTreeCellIdFormat | |
// | |
// Purpose: | |
// Private function to check whether a widgetId is given in specail table cell format (treeId.[row].[column]), | |
// and gives back treeId, row, column if possible | |
// Parameters: | |
// pl_widgetRec - *out* EPTF_UIHandler_GuiItemRec - The <EPTF_UIHandler_GuiItemRec> that describes the specified widget | |
// pl_id - *in* EPTF_UIHandler_WidgetIdString - The input widget Id string | |
// pl_treeId - *out* EPTF_UIHandler_WidgetIdString - The id of the table | |
// pl_row - *out* integer pl_row - The row number of the cell | |
// pl_col - *out* integer - The column number of the cell | |
// Return Value: | |
// True if widgetId is in special format, false otherwise | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_isTreeCellIdFormat( | |
in EPTF_UIHandler_WidgetIdString pl_id, | |
out EPTF_UIHandler_WidgetIdString pl_treeId, | |
out integer pl_row, | |
out integer pl_col ) | |
return boolean { | |
// this function matches pattern "*.[0-9]+.[0-9]+" but without using the unefficient regexp | |
// reset out parameters | |
pl_treeId := ""; | |
pl_row := 0; | |
pl_col := 0; | |
var integer i := lengthof(pl_id)-1, vl_limiterIdx1 := -1, vl_limiterIdx2 := -1; | |
// check last char is a number | |
if ( char2int(pl_id[i])<char2int("0") or char2int(pl_id[i])>char2int("9") ) { | |
return false; | |
} | |
// find first '.' from back in Id | |
for (i := i-1; pl_id[i] != "." and i>=3; i := i-1) { | |
if (char2int(pl_id[i])<char2int("0") or char2int(pl_id[i])>char2int("9")) { | |
return false; | |
} | |
} | |
if (i<3) { | |
return false; | |
} | |
vl_limiterIdx1 := i; | |
// check next char is a number | |
i := i-1; | |
if ( char2int(pl_id[i])<char2int("0") or char2int(pl_id[i])>char2int("9") ) { | |
return false; | |
} | |
// find second '.' from back in Id | |
for (i := i-1; pl_id[i] != "." and i>=1; i := i-1) { | |
if (char2int(pl_id[i])<char2int("0") or char2int(pl_id[i])>char2int("9")) { | |
return false; | |
} | |
} | |
if (i<1) { | |
return false; | |
} | |
vl_limiterIdx2 := i; | |
// obtain column number | |
pl_col := str2int(substr(pl_id, vl_limiterIdx1+1, lengthof(pl_id)-vl_limiterIdx1-1)); | |
// obtain row number | |
pl_row := str2int(substr(pl_id, vl_limiterIdx2 + 1, vl_limiterIdx1 - vl_limiterIdx2 - 1)); | |
// obtain tree id | |
pl_treeId := substr(pl_id, 0, vl_limiterIdx2); | |
return true; | |
} | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_getWidgetRec | |
// Parameters: | |
// pl_widgetRec - *out* EPTF_UIHandler_GuiItemRec - The <EPTF_UIHandler_GuiItemRec> that describes the specified widget | |
// | |
// Return Value: | |
// True if success, false otherwise. | |
/////////////////////////////////////////////////////////// | |
private function f_EPTF_UIHandler_getWidgetRec( | |
in EPTF_UIHandler_WidgetIdString pl_widgetId, | |
out EPTF_UIHandler_GuiItemRec pl_widgetRec) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean{ | |
var integer vl_idx := f_EPTF_UIHandler_widgetRecIndex(pl_widgetId); | |
pl_widgetRec := c_UIHandler_emptyGUIItem; | |
if(-1 < vl_idx){ | |
pl_widgetRec := v_UIHandler_guiItemList[vl_idx]; | |
return true; | |
} | |
return false; | |
} | |
} //EPTF_WidgetAdministrationFunctions group | |
/////////////////////////////////////////////////////////// | |
// Group: EPTF_WidgetAddInternalFunctions | |
/////////////////////////////////////////////////////////// | |
group EPTF_WidgetAddInternalFunctions{ | |
/////////////////////////////////////////////////////////// | |
// Function: f_EPTF_UIHandler_addElementToTree | |
// | |
// Purpose: | |
// Private function to look through a Tree when adding an column or item or row or cell to it. | |
// | |
// Parameters: | |
// pl_parentWidgetId *integer* | |
// pl_xul *XTDP_XML_Tag* | |
// pl_currentTree <Tree> | |
// | |
// Return Value: | |
// *boolean* | |
// | |
// Errors: | |
// none | |
// | |
// Detailed Comments: | |
// Returns true if pl_xul has been added to pl_currentTree. | |
// | |
/////////////////////////////////////////////////////////// | |
/*private function f_EPTF_UIHandler_addElementToTree( | |
in EPTF_UIHandler_WidgetIdString pl_parentWidgetId, | |
in Widgets pl_xul, | |
inout ttcn_ericsson_se_protocolModules_xtdp_xtdl.Tree pl_currentTree) | |
runs on EPTF_UIHandler_Private_CT | |
return boolean { | |
if(pl_currentTree.id == pl_parentWidgetId) { | |
// init the one-and-only treeitem (treechildren[0]): | |
if(sizeof(pl_currentTree.treechildren.treeitemgroups.treeitemgroup_list) == 0) { | |
pl_currentTree.treechildren.treeitemgroups.treeitemgroup_list[0].treeitem.treerowgroups.treerowgroup_list := {}; | |
} | |
select( true ) | |
{ | |
case (ischosen (pl_xul.treecol)) { | |
pl_currentTree.treecols.treecolgroups.treecolgroup_list[sizeof(pl_currentTree.treecols.treecolgroups.treecolgroup_list)].treecol := pl_xul.treecol; | |
return true; | |
} | |
case (ischosen (pl_xul.treecols)) { | |
for(var integer col := 0; col < sizeof(pl_xul.treecols.treecolgroups.treecolgroup_list); col := col + 1) { | |
if(ischosen(pl_xul.treecols.treecolgroups.treecolgroup_list[col].treecol)){ | |
pl_currentTree.treecols.treecolgroups.treecolgroup_list[sizeof(pl_currentTree.treecols.treecolgroups.treecolgroup_list)].treecol := pl_xul.treecols.treecolgroups.treecolgroup_list[col].treecol; | |
}else{ | |
f_EPTF_UIHandler_warning(%definitionId&": Invalid element to be added: "&log2str(pl_xul.treecols.treecolgroups.treecolgroup_list[col])); | |
return false; | |
} | |
} | |
return true; | |
} | |
case (ischosen (pl_xul.treerow)) { | |
pl_currentTree.treechildren.treeitemgroups.treeitemgroup_list[0].treeitem.treerowgroups.treerowgroup_list[sizeof(pl_currentTree.treechildren.treeitemgroups.treeitemgroup_list[0].treeitem.treerowgroups.treerowgroup_list)].treerow := pl_xul.treerow; | |
return true; | |
} | |
case (ischosen (pl_xul.treecell)) { | |