From 68c55663ba82059719deb76e70674c51c1a97815 Mon Sep 17 00:00:00 2001 From: "carina@hades" Date: Mon, 31 Oct 2022 15:00:04 -0400 Subject: [PATCH] restructure folder --- .gitignore | 2 +- ClassData.h => DAQ/ClassData.h | 3 +- ClassDigitizer.cpp => DAQ/ClassDigitizer.cpp | 20 ++-- ClassDigitizer.h => DAQ/ClassDigitizer.h | 0 EventBuilder.cpp => DAQ/EventBuilder.cpp | 0 FSUDAQ.cpp => DAQ/FSUDAQ.cpp | 106 ++++++++++-------- FSUDAQ.h => DAQ/FSUDAQ.h | 2 +- FSUDAQLinkDef.h => DAQ/FSUDAQLinkDef.h | 0 Makefile => DAQ/Makefile | 0 {Obsolete => DAQ/Obsolete}/DigitizerPHA.cpp | 0 {Obsolete => DAQ/Obsolete}/DigitizerPHA.h | 0 {Obsolete => DAQ/Obsolete}/DigitizerPSD.cpp | 0 {Obsolete => DAQ/Obsolete}/DigitizerPSD.h | 0 RegisterAddress.h => DAQ/RegisterAddress.h | 0 boardSetting.cpp => DAQ/boardSetting.cpp | 18 +-- boardSetting.h => DAQ/boardSetting.h | 0 .../channelSettingPHA.cpp | 4 + .../channelSettingPHA.h | 0 .../channelSettingPSD.cpp | 4 + .../channelSettingPSD.h | 0 macro.h => DAQ/macro.h | 0 programSetting.cpp => DAQ/programSetting.cpp | 33 +++++- programSetting.h => DAQ/programSetting.h | 2 + .../registerSetting.cpp | 4 +- registerSetting.h => DAQ/registerSetting.h | 0 test.cpp => DAQ/test.cpp | 0 test_indep.cpp => DAQ/test_indep.cpp | 0 triggerSummary.cpp => DAQ/triggerSummary.cpp | 2 + triggerSummary.h => DAQ/triggerSummary.h | 0 FSUDAQ.sh | 6 + 30 files changed, 133 insertions(+), 73 deletions(-) rename ClassData.h => DAQ/ClassData.h (99%) rename ClassDigitizer.cpp => DAQ/ClassDigitizer.cpp (98%) rename ClassDigitizer.h => DAQ/ClassDigitizer.h (100%) rename EventBuilder.cpp => DAQ/EventBuilder.cpp (100%) rename FSUDAQ.cpp => DAQ/FSUDAQ.cpp (96%) rename FSUDAQ.h => DAQ/FSUDAQ.h (98%) rename FSUDAQLinkDef.h => DAQ/FSUDAQLinkDef.h (100%) rename Makefile => DAQ/Makefile (100%) rename {Obsolete => DAQ/Obsolete}/DigitizerPHA.cpp (100%) rename {Obsolete => DAQ/Obsolete}/DigitizerPHA.h (100%) rename {Obsolete => DAQ/Obsolete}/DigitizerPSD.cpp (100%) rename {Obsolete => DAQ/Obsolete}/DigitizerPSD.h (100%) rename RegisterAddress.h => DAQ/RegisterAddress.h (100%) rename boardSetting.cpp => DAQ/boardSetting.cpp (99%) rename boardSetting.h => DAQ/boardSetting.h (100%) rename channelSettingPHA.cpp => DAQ/channelSettingPHA.cpp (99%) rename channelSettingPHA.h => DAQ/channelSettingPHA.h (100%) rename channelSettingPSD.cpp => DAQ/channelSettingPSD.cpp (99%) rename channelSettingPSD.h => DAQ/channelSettingPSD.h (100%) rename macro.h => DAQ/macro.h (100%) rename programSetting.cpp => DAQ/programSetting.cpp (88%) rename programSetting.h => DAQ/programSetting.h (97%) rename registerSetting.cpp => DAQ/registerSetting.cpp (99%) rename registerSetting.h => DAQ/registerSetting.h (100%) rename test.cpp => DAQ/test.cpp (100%) rename test_indep.cpp => DAQ/test_indep.cpp (100%) rename triggerSummary.cpp => DAQ/triggerSummary.cpp (99%) rename triggerSummary.h => DAQ/triggerSummary.h (100%) create mode 100755 FSUDAQ.sh diff --git a/.gitignore b/.gitignore index 3f04ec3..2efa6ac 100644 --- a/.gitignore +++ b/.gitignore @@ -12,4 +12,4 @@ FSUDAQ test_indep EventBuilder -FSUDAQ.sh +expDir diff --git a/ClassData.h b/DAQ/ClassData.h similarity index 99% rename from ClassData.h rename to DAQ/ClassData.h index 22ef3d8..9211532 100644 --- a/ClassData.h +++ b/DAQ/ClassData.h @@ -97,7 +97,7 @@ class Data{ //========================================== inline Data::Data(){ - + printf("----- %s \n", __func__); ch2ns = 2.0; boardSN = 0; DPPType = V1730_DPP_PHA_CODE; @@ -112,6 +112,7 @@ inline Data::Data(){ } inline Data::~Data(){ + printf("----- %s \n", __func__); delete buffer; } diff --git a/ClassDigitizer.cpp b/DAQ/ClassDigitizer.cpp similarity index 98% rename from ClassDigitizer.cpp rename to DAQ/ClassDigitizer.cpp index 050adb5..5385c1f 100644 --- a/ClassDigitizer.cpp +++ b/DAQ/ClassDigitizer.cpp @@ -1,6 +1,7 @@ #include "ClassDigitizer.h" Digitizer::Digitizer(){ + printf("----- %s \n", __func__); Initalization(); } @@ -10,6 +11,7 @@ Digitizer::Digitizer(int boardID, int portID, bool program, bool verbose){ } Digitizer::~Digitizer(){ + printf("----- %s \n", __func__); delete data; delete settingFile; CloseDigitizer(); @@ -378,14 +380,14 @@ unsigned int Digitizer::CalByteForBuffer(){ } } - printf(" agg. orgainzation (bit) : 0x%X \n", aggOrgan); - printf(" Channel Mask : %04X \n", chMask); - printf("Max number of Agg per Readout : %u \n", numAggBLT); - printf(" is Extra2 enabed : %u \n", ((boardCfg >> 17) & 0x1) ); - printf(" is Record wave : %u \n", ((boardCfg >> 16) & 0x1) ); - for( int pCh = 0; pCh < NChannel/2; pCh++){ - printf("Paired Ch : %d, RecordLength (bit value): %u, Event per Agg. : %u \n", pCh, recordLength[pCh], eventAgg[pCh]); - } + ///printf(" agg. orgainzation (bit) : 0x%X \n", aggOrgan); + ///printf(" Channel Mask : %04X \n", chMask); + ///printf("Max number of Agg per Readout : %u \n", numAggBLT); + ///printf(" is Extra2 enabed : %u \n", ((boardCfg >> 17) & 0x1) ); + ///printf(" is Record wave : %u \n", ((boardCfg >> 16) & 0x1) ); + ///for( int pCh = 0; pCh < NChannel/2; pCh++){ + /// printf("Paired Ch : %d, RecordLength (bit value): %u, Event per Agg. : %u \n", pCh, recordLength[pCh], eventAgg[pCh]); + ///} unsigned int bufferSize = 0; for( int pCh = 0; pCh < NChannel/2 ; pCh++){ @@ -395,7 +397,7 @@ unsigned int Digitizer::CalByteForBuffer(){ bufferSize += 4; /// Bd. Agg Header bufferSize = bufferSize * numAggBLT * 4; /// 1 words = 4 byte - printf("=============== Buffer Size : %8d Byte \n", bufferSize ); + ///printf("=============== Buffer Size : %8d Byte \n", bufferSize ); return bufferSize ; } diff --git a/ClassDigitizer.h b/DAQ/ClassDigitizer.h similarity index 100% rename from ClassDigitizer.h rename to DAQ/ClassDigitizer.h diff --git a/EventBuilder.cpp b/DAQ/EventBuilder.cpp similarity index 100% rename from EventBuilder.cpp rename to DAQ/EventBuilder.cpp diff --git a/FSUDAQ.cpp b/DAQ/FSUDAQ.cpp similarity index 96% rename from FSUDAQ.cpp rename to DAQ/FSUDAQ.cpp index 6300f31..ec9290a 100644 --- a/FSUDAQ.cpp +++ b/DAQ/FSUDAQ.cpp @@ -96,6 +96,8 @@ enum ModeIdentifiers{ MainWindow::MainWindow(const TGWindow *p,UInt_t w,UInt_t h) { + printf("----- %s \n", __func__); + nDigi = 0; gClient->GetColorByName("red", red); @@ -263,7 +265,7 @@ MainWindow::MainWindow(const TGWindow *p,UInt_t w,UInt_t h) { //HandleMenu(M_PROGRAM_SETTINGS); gDummy = new TGraph(); - gDummy->SetPoint(0, 0, -1000); /// the lower left corner + gDummy->SetPoint(0, 0, 0); /// the lower left corner gDummy->GetXaxis()->SetTitle("[ns]"); gAnaTrace1 = new TGraph(); @@ -281,9 +283,39 @@ MainWindow::MainWindow(const TGWindow *p,UInt_t w,UInt_t h) { gStyle->SetOptStat("neiou"); + + DrawDummyGraph(); + +} + +void MainWindow::GoodBye(){ + + for( int i = 0; i < nDigi; i++) digi[i]->CloseDigitizer(); + + for( int i = 0; i < nDigi; i++) delete digi[i]; + + for( int i = 0; i < MaxNBoards; i++){ + delete hChannel[i]; + for( int j = 0; j < MaxNChannels; j++){ + delete hEnergy[i][j]; + } + } + + delete gDummy; + delete gAnaTrace1 ; + delete gAnaTrace2 ; + delete gDigiTrace1; + delete gDigiTrace2; + + printf("----- bye bye ---- \n"); + gApplication->Terminate(0); } + MainWindow::~MainWindow() { + /// The destrcutor is overrided by GoodBye(); + + printf("----- %s \n", __func__); delete fMenuBar; delete fMenuFile; @@ -313,11 +345,8 @@ MainWindow::~MainWindow() { delete registerSetting; delete triggerSummary; delete programSetting; - delete fillHistThread; - - /// Clean up used widgets: frames, buttons, layout hints fMain->Cleanup(); delete fMain; } @@ -326,12 +355,7 @@ void MainWindow::HandleMenu(Int_t id){ ///========================= Scan digitizers case M_DIGITIZER_OPEN:{ - OpenDigitizers(); - - //fMenuDigitizers->EnableEntry( M_BOARD_SETTINGS); - //fMenuDigitizers->EnableEntry( M_CH_SETTING); - }break; ///========================= File Open @@ -486,14 +510,12 @@ void MainWindow::LoadSettingFromFile(){ "Text files", "*.[tT][xX][tT]", 0, 0 }; - static TString dir("."); TGFileInfo fi; fi.fFileTypes = filetypes; - fi.SetIniDir(dir); + fi.SetIniDir("."); printf("fIniDir = %s\n", fi.fIniDir); new TGFileDialog(gClient->GetRoot(), fMain, kFDOpen, &fi); printf("Open file: %s (dir: %s)\n", fi.fFilename, fi.fIniDir); - dir = fi.fIniDir; if( fi.fFilename == NULL) return; @@ -510,10 +532,6 @@ void MainWindow::LoadSettingFromFile(){ loadStatus = digi[0]->LoadSettingBinary( fi.fFilename ); /// still dummy digitizer } - //if( boardSetting != NULL ) boardSetting->CloseWindow(); - //if( channelSettingPHA != NULL ) channelSettingPHA->CloseWindow(); - //if( channelSettingPSD != NULL ) channelSettingPSD->CloseWindow(); - HandleMenu(M_BOARD_SETTINGS); OpenChannelSetting(0); @@ -525,15 +543,6 @@ void MainWindow::ChangeBoard(){ ChangePlot(); } -void MainWindow::GoodBye(){ - - for( int i = 0; i < nDigi; i++) digi[i]->CloseDigitizer(); - - printf("----- bye bye ---- \n"); - gApplication->Terminate(0); - -} - void MainWindow::UpdateExpName(){ dataPrefix->SetText(ProgramSetting::ExpName.c_str()); runIDEntry->SetNumber(lastRunID); @@ -648,6 +657,23 @@ void MainWindow::LogMsg(char * msg){ } +void MainWindow::DrawDummyGraph(){ + + int boardID = boardIDEntry->GetNumber(); + int chID = chIDEntry->GetNumber(); + + int ch2ns = (int) digi[boardID]->GetCh2ns(); + + fEcanvas->GetCanvas()->cd(); + uint32_t rl = digi[boardID]->GetSettingFromMemory(Register::DPP::RecordLength_G, chID); + + gDummy->SetPoint(1, 8.*rl*ch2ns, 0); + gDummy->SetLineColor(15); + gDummy->Draw("AL"); + gDummy->GetXaxis()->SetRangeUser(0, 8*rl*ch2ns); + gDummy->GetYaxis()->SetRangeUser(-1000, 0x3FFF); +} + void MainWindow::PlotSingleTrace(){ printf("=== %s\n", __func__); @@ -668,14 +694,7 @@ void MainWindow::PlotSingleTrace(){ Data * data = digi[boardID]->GetData(); int ch2ns = (int) digi[boardID]->GetCh2ns(); - fEcanvas->GetCanvas()->cd(); - uint32_t rl = digi[boardID]->GetSettingFromMemory(Register::DPP::RecordLength_G, chID); - printf("Record Length = %u \n", rl); - gDummy->SetPoint(1, 0, 0x3FFF); - gDummy->SetPoint(2, 8.*rl*ch2ns, 0x3FFF); - gDummy->Draw("AL"); - gDummy->GetXaxis()->SetRangeUser(0, 8*rl*ch2ns); - gDummy->GetYaxis()->SetRangeUser(-1000, 0x3FFF); + DrawDummyGraph(); digi[boardID]->StartACQ(); @@ -780,10 +799,13 @@ void MainWindow::ChangePlot(){ if( cbMode->GetSelected() == Mode_EnergyHist ) hEnergy[boardID][ch]->Draw("hist"); if( cbMode->GetSelected() == Mode_Oscilloscope ){ + + DrawDummyGraph(); + uint32_t bdConfig = digi[boardID]->GetSettingFromMemory(Register::DPP::BoardConfiguration); bool isDualTrace = ( bdConfig >> 11 ) & 0x1; gAnaTrace1->GetYaxis()->SetRangeUser(0, 0x3FFF); - gAnaTrace1->Draw("APL"); + gAnaTrace1->Draw("L"); if( isDualTrace ) gAnaTrace2->Draw("L"); gDigiTrace1->Draw("L"); } @@ -807,7 +829,7 @@ void * MainWindow::RunThread(void * ptr){ uint32_t CurrentTime = 0; uint32_t ElapsedTime = 0; - TString dataFileName = ProgramSetting::DataSavingPath + dataPrefix->GetText(); + TString dataFileName = ProgramSetting::DataSavingPath + "/" + dataPrefix->GetText(); dataFileName += Form("_run%03d", (int) runIDEntry->GetNumber()); printf("|%s|\n", dataFileName.Data()); @@ -818,6 +840,8 @@ void * MainWindow::RunThread(void * ptr){ Data * data = digi[boardID]->GetData(); + DrawDummyGraph(); + while(digi[boardID]->IsRunning()){ usleep(100*1000); /// wait 100 msec @@ -847,18 +871,6 @@ void * MainWindow::RunThread(void * ptr){ data->DecodeBuffer(false, 0); } } - - if( CurrentTime == 0 ){ - fEcanvas->GetCanvas()->cd(); - - uint32_t rl = digi[boardID]->GetSettingFromMemory(Register::DPP::RecordLength_G, ch); - printf("Record Length = %u \n", rl); - gDummy->SetPoint(1, 0, 0x3FFF); - gDummy->SetPoint(2, 8.*rl*ch2ns, 0x3FFF); - gDummy->Draw("AL"); - gDummy->GetXaxis()->SetRangeUser(0, 8*rl*ch2ns); - gDummy->GetYaxis()->SetRangeUser(-1000, 0x3FFF); - } if( cbMode->GetSelected() != Mode_DataRun){ diff --git a/FSUDAQ.h b/DAQ/FSUDAQ.h similarity index 98% rename from FSUDAQ.h rename to DAQ/FSUDAQ.h index 6d764a0..c509080 100644 --- a/FSUDAQ.h +++ b/DAQ/FSUDAQ.h @@ -91,6 +91,6 @@ public: void UpdateChannelSetting(); void LogMsg(char * ); void GoodBye(); - + static void DrawDummyGraph(); }; diff --git a/FSUDAQLinkDef.h b/DAQ/FSUDAQLinkDef.h similarity index 100% rename from FSUDAQLinkDef.h rename to DAQ/FSUDAQLinkDef.h diff --git a/Makefile b/DAQ/Makefile similarity index 100% rename from Makefile rename to DAQ/Makefile diff --git a/Obsolete/DigitizerPHA.cpp b/DAQ/Obsolete/DigitizerPHA.cpp similarity index 100% rename from Obsolete/DigitizerPHA.cpp rename to DAQ/Obsolete/DigitizerPHA.cpp diff --git a/Obsolete/DigitizerPHA.h b/DAQ/Obsolete/DigitizerPHA.h similarity index 100% rename from Obsolete/DigitizerPHA.h rename to DAQ/Obsolete/DigitizerPHA.h diff --git a/Obsolete/DigitizerPSD.cpp b/DAQ/Obsolete/DigitizerPSD.cpp similarity index 100% rename from Obsolete/DigitizerPSD.cpp rename to DAQ/Obsolete/DigitizerPSD.cpp diff --git a/Obsolete/DigitizerPSD.h b/DAQ/Obsolete/DigitizerPSD.h similarity index 100% rename from Obsolete/DigitizerPSD.h rename to DAQ/Obsolete/DigitizerPSD.h diff --git a/RegisterAddress.h b/DAQ/RegisterAddress.h similarity index 100% rename from RegisterAddress.h rename to DAQ/RegisterAddress.h diff --git a/boardSetting.cpp b/DAQ/boardSetting.cpp similarity index 99% rename from boardSetting.cpp rename to DAQ/boardSetting.cpp index 280a416..f37e627 100644 --- a/boardSetting.cpp +++ b/DAQ/boardSetting.cpp @@ -27,7 +27,8 @@ extern unsigned short nDigi; extern Digitizer ** digi; BoardSetting::BoardSetting(const TGWindow *p, UInt_t w, UInt_t h){ - + printf("----- %s \n", __func__); + fMain = new TGMainFrame(p,w,h); fMain->SetWindowName("Board Settings & Status"); fMain->Connect("CloseWindow()", "BoardSetting", this, "CloseWindow()"); @@ -623,7 +624,7 @@ BoardSetting::BoardSetting(const TGWindow *p, UInt_t w, UInt_t h){ bReadData->Connect("Clicked()", "BoardSetting", this, "ReadData()"); TGTextButton * bCaliADC = new TGTextButton(vfButton, "Calibrate ADC"); vfButton->AddFrame(bCaliADC, new TGLayoutHints( kLHintsExpandX | kLHintsExpandY, 5, 0, 5, 0)); - bCaliADC->Connect("Clicked()", "ChannelSettingPHA", this, "CaliADC()"); + bCaliADC->Connect("Clicked()", "BoardSetting", this, "CaliADC()"); } @@ -770,7 +771,7 @@ BoardSetting::BoardSetting(const TGWindow *p, UInt_t w, UInt_t h){ } BoardSetting::~BoardSetting(){ - + printf("----- %s \n", __func__); isOpened = false; printf("close BoardSetting window\n"); @@ -1477,19 +1478,14 @@ void BoardSetting::ProgramDefaultBoard(){ void BoardSetting::ProgramBoardFromFile(){ const char *filetypes[] = { "Setting File", "*.bin", - "ROOT files", "*.root", - "ROOT macros", "*.C", - "Text files", "*.[tT][xX][tT]", 0, 0 }; - static TString dir("."); TGFileInfo fi; fi.fFileTypes = filetypes; - fi.SetIniDir(dir); + fi.SetIniDir("."); printf("fIniDir = %s\n", fi.fIniDir); new TGFileDialog(gClient->GetRoot(), fMain, kFDOpen, &fi); printf("Open file: %s (dir: %s)\n", fi.fFilename, fi.fIniDir); - dir = fi.fIniDir; if( fi.fFilename == NULL) return; @@ -1517,14 +1513,12 @@ void BoardSetting::SaveSettingFile(){ "Text File", "*.txt", 0, 0}; - static TString dir("."); TGFileInfo fi; fi.fFileTypes = filetypes; - fi.SetIniDir(dir); + fi.SetIniDir("."); printf("fIniDir = %s\n", fi.fIniDir); new TGFileDialog(gClient->GetRoot(), fMain, kFDSave, &fi); printf("Open file: %s (dir: %s)\n", fi.fFilename, fi.fIniDir); - dir = fi.fIniDir; if( fi.fFilename == NULL) return; diff --git a/boardSetting.h b/DAQ/boardSetting.h similarity index 100% rename from boardSetting.h rename to DAQ/boardSetting.h diff --git a/channelSettingPHA.cpp b/DAQ/channelSettingPHA.cpp similarity index 99% rename from channelSettingPHA.cpp rename to DAQ/channelSettingPHA.cpp index 4f45c08..0892893 100644 --- a/channelSettingPHA.cpp +++ b/DAQ/channelSettingPHA.cpp @@ -18,6 +18,8 @@ extern Digitizer ** digi; ChannelSettingPHA::ChannelSettingPHA(const TGWindow *p, UInt_t w, UInt_t h, int boardID){ + printf("----- %s \n", __func__); + fMain = new TGMainFrame(p,w,h); fMain->SetWindowName("Channel Settings PHA"); fMain->Connect("CloseWindow()", "ChannelSettingPHA", this, "CloseWindow()"); @@ -459,6 +461,8 @@ ChannelSettingPHA::ChannelSettingPHA(const TGWindow *p, UInt_t w, UInt_t h, int } ChannelSettingPHA::~ChannelSettingPHA(){ + printf("----- %s \n", __func__); + printf("close ChannelSettingPHA window\n"); isOpened = false; diff --git a/channelSettingPHA.h b/DAQ/channelSettingPHA.h similarity index 100% rename from channelSettingPHA.h rename to DAQ/channelSettingPHA.h diff --git a/channelSettingPSD.cpp b/DAQ/channelSettingPSD.cpp similarity index 99% rename from channelSettingPSD.cpp rename to DAQ/channelSettingPSD.cpp index 383070b..4798862 100644 --- a/channelSettingPSD.cpp +++ b/DAQ/channelSettingPSD.cpp @@ -16,6 +16,8 @@ extern Digitizer ** digi; ChannelSettingPSD::ChannelSettingPSD(const TGWindow *p, UInt_t w, UInt_t h, int boardID){ + printf("----- %s \n", __func__); + fMain = new TGMainFrame(p,w,h); fMain->SetWindowName("Channel Settings PSD"); fMain->Connect("CloseWindow()", "ChannelSettingPSD", this, "CloseWindow()"); @@ -467,6 +469,8 @@ ChannelSettingPSD::ChannelSettingPSD(const TGWindow *p, UInt_t w, UInt_t h, int } ChannelSettingPSD::~ChannelSettingPSD(){ + printf("----- %s \n", __func__); + printf("close ChannelSettingPSD window\n"); isOpened = false; diff --git a/channelSettingPSD.h b/DAQ/channelSettingPSD.h similarity index 100% rename from channelSettingPSD.h rename to DAQ/channelSettingPSD.h diff --git a/macro.h b/DAQ/macro.h similarity index 100% rename from macro.h rename to DAQ/macro.h diff --git a/programSetting.cpp b/DAQ/programSetting.cpp similarity index 88% rename from programSetting.cpp rename to DAQ/programSetting.cpp index 84defed..2ecda15 100644 --- a/programSetting.cpp +++ b/DAQ/programSetting.cpp @@ -14,7 +14,7 @@ std::string ProgramSetting::databaseIP = "http://fsunuc.physics.fsu.edu/influx/"; std::string ProgramSetting::databaseName = "testing"; -std::string ProgramSetting::DataSavingPath = "/home/catrina/FSUDAQ/"; +std::string ProgramSetting::DataSavingPath = "/home/catrina/FSUDAQ"; std::string ProgramSetting::ExpName = "Test"; std::string ProgramSetting::ElogIP = "128.186.111.127"; @@ -24,6 +24,9 @@ const std::string ProgramSetting::settingFileName = "FSUDAQ.sh"; extern unsigned short lastRunID; ProgramSetting::ProgramSetting(const TGWindow *p){ + + printf("----- %s \n", __func__); + fMain = new TGMainFrame(p, 600, 400); fMain->SetWindowName("Program Setting"); fMain->Connect("CloseWindow()", "ProgramSetting", this, "CloseWindow()"); @@ -40,6 +43,7 @@ ProgramSetting::ProgramSetting(const TGWindow *p){ TGVerticalFrame * vfLabel = new TGVerticalFrame(hfData, 200); hfData->AddFrame(vfLabel ); TGVerticalFrame * vfTxt = new TGVerticalFrame(hfData); hfData->AddFrame(vfTxt); + TGVerticalFrame * vfAux = new TGVerticalFrame(hfData); hfData->AddFrame(vfAux); TGLabel * lbExpName = new TGLabel(vfLabel, "ExpName :"); vfLabel->AddFrame(lbExpName, haha); TGLabel * lbDataPath = new TGLabel(vfLabel, "Data Absolute Path :"); vfLabel->AddFrame(lbDataPath, haha); @@ -52,6 +56,12 @@ ProgramSetting::ProgramSetting(const TGWindow *p){ txtDataPath->Connect("ReturnPressed()", "ProgramSetting", this, "SetSetting()"); txtDataPath->Resize(300, 20); + + TGLabel * lbdummy0 = new TGLabel(vfAux, ""); vfAux->AddFrame(lbdummy0, haha); + + TGTextButton * bSetFolder = new TGTextButton(vfAux, "Set Folder"); vfAux->AddFrame(bSetFolder, kaka); + bSetFolder->Connect("Clicked()", "ProgramSetting", this, "SetFolder()"); + } {///============== Database & Elog @@ -91,6 +101,8 @@ ProgramSetting::ProgramSetting(const TGWindow *p){ ProgramSetting::~ProgramSetting(){ + printf("----- %s \n", __func__); + delete txtIP; delete txtDBName; delete txtDataPath; @@ -119,6 +131,25 @@ void ProgramSetting::SetSetting(){ } +void ProgramSetting::SetFolder(){ + + const char *filetypes[] = { "All Files", "*.*", 0, 0 }; + + TGFileInfo fi; + fi.fFileTypes = filetypes; + fi.SetIniDir("."); + printf("fIniDir = %s\n", fi.fIniDir); + new TGFileDialog(gClient->GetRoot(), fMain, kDOpen, &fi); + printf("Open file: %s (dir: %s)\n", fi.fFilename, fi.fIniDir); + + if( fi.fFilename == NULL) return; + + txtDataPath->SetText(fi.fFilename); + + SetSetting(); + +} + void ProgramSetting::PrintSettings(){ printf("Data Saving Path : %s\n", DataSavingPath.c_str()); diff --git a/programSetting.h b/DAQ/programSetting.h similarity index 97% rename from programSetting.h rename to DAQ/programSetting.h index d6643ea..79ded1b 100644 --- a/programSetting.h +++ b/DAQ/programSetting.h @@ -46,6 +46,8 @@ class ProgramSetting{ static void LoadProgramSetting(); static void SaveProgramSetting(); + void SetFolder(); + }; #endif diff --git a/registerSetting.cpp b/DAQ/registerSetting.cpp similarity index 99% rename from registerSetting.cpp rename to DAQ/registerSetting.cpp index 2347641..653f0cf 100644 --- a/registerSetting.cpp +++ b/DAQ/registerSetting.cpp @@ -13,7 +13,9 @@ extern unsigned short nDigi; extern Digitizer ** digi; RegisterSetting::RegisterSetting(const TGWindow *p, UInt_t w, UInt_t h, uint32_t address){ - + + printf("----- %s \n", __func__); + for( int i = 0; i < MaxNChannels; i++) value[i] = 0; fMain = new TGMainFrame(p,w,h); diff --git a/registerSetting.h b/DAQ/registerSetting.h similarity index 100% rename from registerSetting.h rename to DAQ/registerSetting.h diff --git a/test.cpp b/DAQ/test.cpp similarity index 100% rename from test.cpp rename to DAQ/test.cpp diff --git a/test_indep.cpp b/DAQ/test_indep.cpp similarity index 100% rename from test_indep.cpp rename to DAQ/test_indep.cpp diff --git a/triggerSummary.cpp b/DAQ/triggerSummary.cpp similarity index 99% rename from triggerSummary.cpp rename to DAQ/triggerSummary.cpp index d2abed5..89b742b 100644 --- a/triggerSummary.cpp +++ b/DAQ/triggerSummary.cpp @@ -22,6 +22,8 @@ unsigned short TriggerSummary::value[MaxNBoards][MaxNChannels] = {0}; TriggerSummary::TriggerSummary(const TGWindow *p, UInt_t w, UInt_t h){ + printf("----- %s \n", __func__); + fMain = new TGMainFrame(p,w,h); fMain->SetWindowName("Scalar Panel"); fMain->Connect("CloseWindow()", "TriggerSummary", this, "CloseWindow()"); diff --git a/triggerSummary.h b/DAQ/triggerSummary.h similarity index 100% rename from triggerSummary.h rename to DAQ/triggerSummary.h diff --git a/FSUDAQ.sh b/FSUDAQ.sh new file mode 100755 index 0000000..f29f1f6 --- /dev/null +++ b/FSUDAQ.sh @@ -0,0 +1,6 @@ +ExpName = ZZZZZ +DataPath = /home/catrina/FSUDAQ/expDir +DatabaseIP = http://fsunuc.physics.fsu.edu/influx/ +DatabaseName = testing +ElogIP = 128.186.111.127 +lastRunID = 10