wanpipe/util/wancfg/menu_e1_lbo.cpp

262 lines
7.2 KiB
C++

/***************************************************************************
menu_e1_lbo.cpp - description
-------------------
begin : Wed Apr 28 2004
copyright : (C) 2004 by David Rokhvarg
email : davidr@sangoma.com
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#include "menu_e1_lbo.h"
#include "text_box.h"
#define DBG_MENU_E1_LBO 1
menu_e1_lbo::menu_e1_lbo(IN char * lxdialog_path, IN conf_file_reader* ptr_cfr)
{
Debug(DBG_MENU_E1_LBO, ("menu_e1_lbo::menu_e1_lbo()\n"));
snprintf(this->lxdialog_path, MAX_PATH_LENGTH, "%s", lxdialog_path);
this->cfr = ptr_cfr;
}
menu_e1_lbo::~menu_e1_lbo()
{
Debug(DBG_MENU_E1_LBO, ("menu_e1_lbo::~menu_e1_lbo()\n"));
}
int menu_e1_lbo::run(OUT int * selection_index)
{
string menu_str;
int rc;
char tmp_buff[MAX_PATH_LENGTH];
char exit_dialog;
int number_of_items;
unsigned char old_media;
//help text box
text_box tb;
link_def_t * link_def;
wandev_conf_t *linkconf;
Debug(DBG_MENU_E1_LBO, ("menu_e1_lbo::run()\n"));
again:
link_def = cfr->link_defs;
linkconf = cfr->link_defs->linkconf;
Debug(DBG_MENU_E1_LBO, ("cfr->link_defs->name: %s\n", link_def->name));
rc = YES;
exit_dialog = NO;
old_media = linkconf->fe_cfg.media;
Debug(DBG_MENU_E1_LBO, ("linkconf->card_type: DEC:%d, HEX: 0x%X\n",
linkconf->card_type, linkconf->card_type));
number_of_items = 2;
menu_str = " ";
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"%d\" ", WAN_E1_120);
menu_str += (char*)tmp_buff;
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"120 OH (Default)\" ");
menu_str += tmp_buff;
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"%d\" ", WAN_E1_75);
menu_str += tmp_buff;
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"75 OH\" ");
menu_str += tmp_buff;
//////////////////////////////////////////////////////////////////////////////////////
//create the explanation text for the menu
snprintf(tmp_buff, MAX_PATH_LENGTH,
"\n------------------------------------------\
\nSelect Line Build Out for Wan Device: %s", link_def->name);
if(set_configuration( YES,//indicates to call V2 of the function
MENU_BOX_BACK,//MENU_BOX_SELECT,
lxdialog_path,
"SELECT LINE BUILD OUT",
WANCFG_PROGRAM_NAME,
tmp_buff,
MENU_HEIGTH, MENU_WIDTH,
number_of_items,
(char*)menu_str.c_str()
) == NO){
rc = NO;
goto cleanup;
}
if(show(selection_index) == NO){
rc = NO;
goto cleanup;
}
//////////////////////////////////////////////////////////////////////////////////////
exit_dialog = NO;
switch(*selection_index)
{
case MENU_BOX_BUTTON_SELECT:
Debug(DBG_MENU_E1_LBO,
("hardware_setup: option selected for editing: %s\n", get_lxdialog_output_string()));
linkconf->fe_cfg.cfg.te_cfg.lbo = atoi(get_lxdialog_output_string());
exit_dialog = YES;
break;
case MENU_BOX_BUTTON_HELP:
switch(atoi(get_lxdialog_output_string()))
{
default:
tb.show_help_message(lxdialog_path, NO_PROTOCOL_NEEDED,
option_not_implemented_yet_help_str);
break;
}
break;
case MENU_BOX_BUTTON_EXIT:
exit_dialog = YES;
break;
}//switch(*selection_index)
if(exit_dialog == NO){
goto again;
}
cleanup:
return rc;
}
/////////////////////////////////////////////////////////////////////////////////
// E1 signalling mode part
menu_e1_signalling_mode::menu_e1_signalling_mode(IN char * lxdialog_path, IN conf_file_reader* ptr_cfr)
{
Debug(DBG_MENU_E1_LBO, ("menu_e1_signalling_mode::menu_e1_signalling_mode()\n"));
snprintf(this->lxdialog_path, MAX_PATH_LENGTH, "%s", lxdialog_path);
this->cfr = ptr_cfr;
}
menu_e1_signalling_mode::~menu_e1_signalling_mode()
{
Debug(DBG_MENU_E1_LBO, ("menu_e1_signalling_mode::~menu_e1_signalling_mode()\n"));
}
int menu_e1_signalling_mode::run(OUT int * selection_index)
{
string menu_str;
int rc;
char tmp_buff[MAX_PATH_LENGTH];
char exit_dialog;
int number_of_items;
//help text box
text_box tb;
link_def_t * link_def;
wandev_conf_t *linkconf;
Debug(DBG_MENU_E1_LBO, ("menu_e1_signalling_mode::run()\n"));
again:
link_def = cfr->link_defs;
linkconf = cfr->link_defs->linkconf;
Debug(DBG_MENU_E1_LBO, ("cfr->link_defs->name: %s\n", link_def->name));
rc = YES;
exit_dialog = NO;
Debug(DBG_MENU_E1_LBO, ("linkconf->card_type: DEC:%d, HEX: 0x%X\n",
linkconf->card_type, linkconf->card_type));
number_of_items = 2;
menu_str = " ";
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"%d\" ", WAN_TE1_SIG_CCS);
menu_str += (char*)tmp_buff;
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"CCS (Default)\" ");
menu_str += tmp_buff;
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"%d\" ", WAN_TE1_SIG_CAS);
menu_str += tmp_buff;
snprintf(tmp_buff, MAX_PATH_LENGTH, " \"CAS\" ");
menu_str += tmp_buff;
//////////////////////////////////////////////////////////////////////////////////////
//create the explanation text for the menu
snprintf(tmp_buff, MAX_PATH_LENGTH,
"\n------------------------------------------\
\nSelect E1 Signalling Mode for Wan Device: %s", link_def->name);
if(set_configuration( YES,//indicates to call V2 of the function
MENU_BOX_BACK,//MENU_BOX_SELECT,
lxdialog_path,
"SELECT E1 SIGNALLING MODE",
WANCFG_PROGRAM_NAME,
tmp_buff,
MENU_HEIGTH, MENU_WIDTH,
number_of_items,
(char*)menu_str.c_str()
) == NO){
rc = NO;
goto cleanup;
}
if(show(selection_index) == NO){
rc = NO;
goto cleanup;
}
//////////////////////////////////////////////////////////////////////////////////////
exit_dialog = NO;
switch(*selection_index)
{
case MENU_BOX_BUTTON_SELECT:
Debug(DBG_MENU_E1_LBO,
("hardware_setup: option selected for editing: %s\n", get_lxdialog_output_string()));
linkconf->fe_cfg.cfg.te_cfg.sig_mode = atoi(get_lxdialog_output_string());
exit_dialog = YES;
break;
case MENU_BOX_BUTTON_HELP:
switch(atoi(get_lxdialog_output_string()))
{
default:
tb.show_help_message(lxdialog_path, NO_PROTOCOL_NEEDED,
option_not_implemented_yet_help_str);
break;
}
break;
case MENU_BOX_BUTTON_EXIT:
exit_dialog = YES;
break;
}//switch(*selection_index)
if(exit_dialog == NO){
goto again;
}
cleanup:
return rc;
}