// // // // // This class acts as a data store for the interface and calls for data as required // #include "hpdata.h" #include "global.h" #include "errorhandler.h" #define FUNC_NUM 9 const QString hpCalcData::func_list[FUNC_NUM][2]={{"Application Library",":/icons/apps_32x32.png"}, {"CAS Vars",":/icons/casFolder_32x32.png"}, {"Complex",":/icons/complex_32x32.png"}, {"Lists",":/icons/list_32x32.png"}, {"Matrices",":/icons/table_32x32.png"}, {"Notes",":/icons/note_32x32.png"}, {"Programs",":/icons/program_32x32.png"}, {"Real",":/icons/real_32x32.png"}, {"Variables",":/icons/varFolder_32x32.png"} }; const DataType hpCalcData::func_type[FUNC_NUM]={HP_APP, HP_CAS, HP_COMPLEX, HP_LIST, HP_MATRIC, HP_NOTE, HP_PROG, HP_REAL, HP_VAR }; //constructor hpCalcData::hpCalcData(hpusb * handle) :QObject() { hp_api = handle; //open usb port and store the handle if (hp_api) { hp_api->hp_open(getHandle()); } } //return the interface class hp_Handle * hpCalcData::getHandle() { return &hp_handle; } //return the interface class hpusb * hpCalcData::getAPI() { return hp_api; } //data managment hp_Information hpCalcData::getInfo() { return hp_info; } //get Name QString hpCalcData::getName() { return hp_info.name; } //get Settings hp_Settings hpCalcData::getSettings() { return hp_homesettings; } //read Settings via usb void hpCalcData::readSettings() { hpusb * api; hp_Handle * handle; hp_Settings hpset; log("Reading Settings"); qDebug()<<"Reading Settings"; api=getAPI(); handle=getHandle(); if (api) { if(handle) { qDebug()<usbhandle); if (api) { api->get_settings(handle,&hpset); } } } hp_homesettings=hpset; hp_Change change; change.dataChange=HP_MAIN; emit dataChanged(change); } //set Settings int hpCalcData::setSettings(hp_Settings set) { hp_homesettings=set; } void hpCalcData::setInfo(hp_Information dtype) { hp_info=dtype; return; } //read information via hp interface void hpCalcData::readInfo() { hpusb * api; hp_Handle * handle; hp_Information hpinfo; api=getAPI(); handle=getHandle(); if (api) { if(handle) { qDebug()<usbhandle); if (api) api->load_info(handle,&hpinfo); } } hp_info=hpinfo; hp_Change change; change.dataChange=HP_MAIN; emit dataChanged(change); } void hpCalcData::vpkt_send_experiments(int cmd) { hpusb * api; hp_Handle * handle; api=getAPI(); handle=getHandle(); if (api) { if(handle) { if (api) api->vpkt_send_experiments(handle,cmd); } } } hpCalcData::~hpCalcData() { };