added muSR data run header information dump to musredit

This commit is contained in:
2012-05-25 13:32:28 +00:00
parent 53b305ccdf
commit ec385b1d3a
8 changed files with 294 additions and 0 deletions

View File

@ -6,6 +6,7 @@
changes since 0.11.0 changes since 0.11.0
=================================== ===================================
NEW 2012-05-25 musredit: added a dump muSR data header file information.
NEW 2012-05-22 added spin rotation angle to the LEM MusrRoot file. NEW 2012-05-22 added spin rotation angle to the LEM MusrRoot file.
NEW 2012-05-12 added dump_header. This is a little program which dumps the NEW 2012-05-12 added dump_header. This is a little program which dumps the
header information of a given muSR data file onto the standard header information of a given muSR data file onto the standard

View File

@ -0,0 +1,158 @@
/****************************************************************************
PDumpOutputHandler.cpp
Author: Andreas Suter
e-mail: andreas.suter@psi.ch
$Id$
*****************************************************************************/
/***************************************************************************
* Copyright (C) 2012 by Andreas Suter *
* andreas.suter@psi.ch *
* *
* 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. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#include <QTimer>
#include <QtDebug>
#include "PDumpOutputHandler.h"
//----------------------------------------------------------------------------------------------------
/**
* <p>Sets up the dump output handler GUI and starts the actual dump_header command
*
* \param cmd command string vector. From this the actual dump_header command will be generated and executed.
*/
PDumpOutputHandler::PDumpOutputHandler(QVector<QString> &cmd)
{
if (cmd.empty())
return;
// Layout
fVbox = new QVBoxLayout( this );
fOutput = new QTextEdit();
fVbox->addWidget(fOutput);
fOutput->setMinimumSize(600, 755);
fOutput->setReadOnly(true);
connect( fOutput, SIGNAL( destroyed() ), this, SLOT( quitButtonPressed() ) );
fQuitButton = new QPushButton( tr("Quit") );
fVbox->addWidget(fQuitButton);
connect( fQuitButton, SIGNAL( clicked() ), this, SLOT( quitButtonPressed() ) );
resize( 600, 800 );
fQuitButton->setFocus();
// QProcess related code
fProc = new QProcess( this );
// fProc->setWorkingDirectory(workingDirectory);
// Set up the command and arguments.
QString program = cmd[0];
QStringList arguments;
for (int i=1; i<cmd.size(); i++)
arguments << cmd[i];
connect( fProc, SIGNAL( readyReadStandardOutput() ), this, SLOT( readFromStdOut() ) );
connect( fProc, SIGNAL( readyReadStandardError() ), this, SLOT( readFromStdErr() ) );
// connect( fProc, SIGNAL( finished(int, QProcess::ExitStatus) ), this, SLOT( processDone(int, QProcess::ExitStatus) ) );
fProc->start(program, arguments);
if ( !fProc->waitForStarted() ) {
// error handling
QString msg(tr("Could not execute the output command: ")+cmd[0]);
QMessageBox::critical( 0,
tr("Fatal error"),
msg,
tr("Quit") );
done(0);
}
fProcPID = fProc->pid();
}
//----------------------------------------------------------------------------------------------------
/**
* <p>Destructor. Checks if the a dump_header is still running and if yes try to kill it.
*/
PDumpOutputHandler::~PDumpOutputHandler()
{
if (fProc->state() == QProcess::Running) {
fProc->terminate();
if (!fProc->waitForFinished()) {
qDebug() << "fProc still running, will call kill." << endl;
fProc->kill();
}
fProc->waitForFinished();
}
if (fProc->state() == QProcess::Running) {
QString cmd = "kill -9 "+ fProcPID;
QString msg = "fProc still running even after Qt kill, will try system kill cmd: "+cmd;
qDebug() << msg << endl;
system(cmd.toLatin1());
}
if (fProc) {
delete fProc;
fProc = 0;
}
}
//----------------------------------------------------------------------------------------------------
/**
* <p>Captures the standard output and adds it to the output text edit.
*/
void PDumpOutputHandler::readFromStdOut()
{
// Read and process the data.
// Bear in mind that the data might be output in chunks.
fOutput->append( fProc->readAllStandardOutput() );
}
//----------------------------------------------------------------------------------------------------
/**
* <p>Captures the standard error and adds it to the output text edit.
*/
void PDumpOutputHandler::readFromStdErr()
{
// Read and process the data.
// Bear in mind that the data might be output in chunks.
fOutput->append( fProc->readAllStandardError() );
}
//----------------------------------------------------------------------------------------------------
/**
* <p>If the quit button is pressed while the dump_header is still running, try to terminate dump_header, if this
* does not work, try to kill dump_header.
*/
void PDumpOutputHandler::quitButtonPressed()
{
// if the fitting is still taking place, kill it
if (fProc->state() == QProcess::Running) {
fProc->terminate();
if (!fProc->waitForFinished()) {
fProc->kill();
}
}
accept();
}
//----------------------------------------------------------------------------------------------------
// END
//----------------------------------------------------------------------------------------------------

View File

@ -0,0 +1,74 @@
/****************************************************************************
PDumpOutputHandler.h
Author: Andreas Suter
e-mail: andreas.suter@psi.ch
$Id$
*****************************************************************************/
/***************************************************************************
* Copyright (C) 2012 by Andreas Suter *
* andreas.suter@psi.ch *
* *
* 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. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#ifndef _PDUMPOUTPUTHANDLER_H_
#define _PDUMPOUTPUTHANDLER_H_
#include <QObject>
#include <QProcess>
#include <QDialog>
#include <QVBoxLayout>
#include <QTextEdit>
#include <QPushButton>
#include <QMessageBox>
#include <QVector>
#include <cstdlib>
//---------------------------------------------------------------------------------------
/**
* <p>This class is the capturing the output of musrfit and displays it in a dialog so
* the user has the chance to follow the fitting process, warnings, error messages of
* musrfit.
*/
class PDumpOutputHandler : public QDialog
{
Q_OBJECT
public:
PDumpOutputHandler(QVector<QString> &cmd);
virtual ~PDumpOutputHandler();
private slots:
virtual void readFromStdOut();
virtual void readFromStdErr();
virtual void quitButtonPressed();
private:
Q_PID fProcPID; ///< keeps the process PID
QProcess *fProc; ///< pointer to the dump_header process
QVBoxLayout *fVbox; ///< pointer to the dialog layout manager
QTextEdit *fOutput; ///< the captured dump_header output is written (read only) into this text edit object.
QPushButton *fQuitButton; ///< quit button
};
#endif // _PDUMPOUTPUTHANDLER_H_

View File

@ -68,6 +68,7 @@ using namespace std;
#include "PReplaceDialog.h" #include "PReplaceDialog.h"
#include "PReplaceConfirmationDialog.h" #include "PReplaceConfirmationDialog.h"
#include "PFitOutputHandler.h" #include "PFitOutputHandler.h"
#include "PDumpOutputHandler.h"
#include "PPrefsDialog.h" #include "PPrefsDialog.h"
#include "PGetDefaultDialog.h" #include "PGetDefaultDialog.h"
#include "PMusrEditAbout.h" #include "PMusrEditAbout.h"
@ -551,6 +552,15 @@ void PTextEdit::setupMusrActions()
connect( a, SIGNAL( triggered() ), this, SLOT( musrPrefs() ) ); connect( a, SIGNAL( triggered() ), this, SLOT( musrPrefs() ) );
tb->addAction(a); tb->addAction(a);
menu->addAction(a); menu->addAction(a);
menu->addSeparator();
tb->addSeparator();
a = new QAction( QIcon( QPixmap(":/images/musrdump.xpm")), tr( "&Dump Header"), this);
a->setStatusTip( tr("Dumps muSR File Header Information") );
connect( a, SIGNAL(triggered()), this, SLOT(musrDump()));
tb->addAction(a);
menu->addAction(a);
} }
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
@ -2207,6 +2217,25 @@ void PTextEdit::musrSwapMsrMlog()
} }
} }
//----------------------------------------------------------------------------------------------------
/**
* <p>Dumps the run header information of a selected muSR data file.
*/
void PTextEdit::musrDump()
{
// select a muSR data filename
QString fileName = QFileDialog::getOpenFileName(this, tr("Select muSR Data File"), "./", tr("muSR Data Files (*.root *.bin *.msr *.nxs)"));
QVector<QString> cmd;
QString str = fAdmin->getExecPath() + "/dump_header";
cmd.append(str);
cmd.append(fileName);
PDumpOutputHandler dumpOutputHandler(cmd);
dumpOutputHandler.setModal(false);
dumpOutputHandler.exec();
}
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
/** /**
* <p>Starts the help content browser. * <p>Starts the help content browser.

View File

@ -124,6 +124,7 @@ private slots:
void musrT0(); void musrT0();
void musrPrefs(); void musrPrefs();
void musrSwapMsrMlog(); void musrSwapMsrMlog();
void musrDump();
void helpContents(); void helpContents();
void helpAboutQt(); void helpAboutQt();

View File

@ -0,0 +1,28 @@
/* XPM */
static char * musrdump_xpm[] = {
"22 22 3 1",
" c None",
". c #0000FF",
"+ c #000000",
"... . . . . ... ",
". . . . .. .. . .",
". . . . . . . . .",
". . . . . . . . .",
". . . . . . ... ",
". . . . . . . ",
"... ... . . . ",
" ",
" ",
"+++ ",
" ++++ ",
" + ",
" ++++ ",
" + ",
" ++++ ",
" + + ",
" + +++++ ",
" + +++ ",
" ++++ + ",
" +++ +++ ",
" + ++++ ",
" +++ + "};

View File

@ -81,6 +81,7 @@ HEADERS = musredit.h \
PReplaceDialog.h \ PReplaceDialog.h \
PReplaceConfirmationDialog.h \ PReplaceConfirmationDialog.h \
PFitOutputHandler.h \ PFitOutputHandler.h \
PDumpOutputHandler.h \
PPrefsDialog.h \ PPrefsDialog.h \
PGetDefaultDialog.h \ PGetDefaultDialog.h \
PGetTitleBlockDialog.h \ PGetTitleBlockDialog.h \
@ -103,6 +104,7 @@ SOURCES = PHelp.cpp \
PReplaceDialog.cpp \ PReplaceDialog.cpp \
PReplaceConfirmationDialog.cpp \ PReplaceConfirmationDialog.cpp \
PFitOutputHandler.cpp \ PFitOutputHandler.cpp \
PDumpOutputHandler.cpp \
PPrefsDialog.cpp \ PPrefsDialog.cpp \
PGetDefaultDialog.cpp \ PGetDefaultDialog.cpp \
PGetTitleBlockDialog.cpp \ PGetTitleBlockDialog.cpp \

View File

@ -22,6 +22,7 @@
<file>images/musrswap.xpm</file> <file>images/musrswap.xpm</file>
<file>images/musrt0.xpm</file> <file>images/musrt0.xpm</file>
<file>images/musrview.xpm</file> <file>images/musrview.xpm</file>
<file>images/musrdump.xpm</file>
<file>latex_images/abragam.png</file> <file>latex_images/abragam.png</file>
<file>latex_images/asymmetry.png</file> <file>latex_images/asymmetry.png</file>
<file>latex_images/bessel.png</file> <file>latex_images/bessel.png</file>