-
Hahn, Steven authoredHahn, Steven authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
AddNote.cpp 5.03 KiB
#include "MantidAlgorithms/AddNote.h"
#include "MantidAPI/MatrixWorkspace.h"
#include "MantidKernel/DateTimeValidator.h"
#include "MantidKernel/MandatoryValidator.h"
#include "MantidKernel/TimeSeriesProperty.h"
#include "boost/date_time/local_time/posix_time_zone.hpp"
namespace Mantid {
namespace Algorithms {
using namespace API;
using namespace Kernel;
namespace {
/**
* Creates/updates the named log on the given run.
* @param run A reference to the run object that stores the logs
* @param name The name of the log that is to be either created or updated
* @param time A time string in ISO format, passed to the DateAndTime
* constructor
* @param value The value at the given time
*/
void createOrUpdateValue(API::Run &run, const std::string &name,
const std::string &time, const std::string &value) {
TimeSeriesProperty<std::string> *timeSeries(nullptr);
if (run.hasProperty(name)) {
timeSeries =
dynamic_cast<TimeSeriesProperty<std::string> *>(run.getLogData(name));
if (!timeSeries)
throw std::invalid_argument(
"Log '" + name +
"' already exists but the values are a different type.");
} else {
timeSeries = new TimeSeriesProperty<std::string>(name);
run.addProperty(timeSeries);
}
timeSeries->addValue(time, value);
}
}
// Register the algorithm into the AlgorithmFactory
DECLARE_ALGORITHM(AddNote)
//----------------------------------------------------------------------------------------------
AddNote::AddNote() { useAlgorithm("Comment", 1); }
//----------------------------------------------------------------------------------------------
/// Algorithms name for identification. @see Algorithm::name
const std::string AddNote::name() const { return "AddNote"; }
/// Algorithm's version for identification. @see Algorithm::version
int AddNote::version() const { return 1; }
/// Algorithm's category for identification. @see Algorithm::category
const std::string AddNote::category() const { return "DataHandling\\Logs"; }
/// Algorithm's summary for use in the GUI and help. @see Algorithm::summary
const std::string AddNote::summary() const {
return "Adds a timestamped note to a workspace.";
}
//----------------------------------------------------------------------------------------------
/** Initialize the algorithm's properties.
*/
void AddNote::init() {
declareProperty(make_unique<WorkspaceProperty<MatrixWorkspace>>(
"Workspace", "", Direction::InOut),
"An InOut workspace that will store the new log information");
declareProperty("Name", "",
boost::make_shared<MandatoryValidator<std::string>>(),
"A String name for either a new time series log to be "
"created or an existing name to update",
Direction::Input);
auto dtv = boost::make_shared<DateTimeValidator>();
dtv->allowEmpty(true);
declareProperty(
"Time", "", dtv,
"An ISO formatted date/time string specifying the timestamp for "
"the given log value, for example 2010-09-14T04:20:12 \n"
"If left blank, this will default to the current Date and Time",
Direction::Input);
declareProperty(
"Value", "", boost::make_shared<MandatoryValidator<std::string>>(),
"A String value for the series log at the given time", Direction::Input);
declareProperty(
"DeleteExisting", false,
"If true and the named log exists then the whole log is removed first.",
Direction::Input);
}
//----------------------------------------------------------------------------------------------
/** Executes the algorithm.
*/
void AddNote::exec() {
MatrixWorkspace_sptr logWS = getProperty("Workspace");
std::string name = getProperty("Name");
const bool deleteExisting = getProperty("DeleteExisting");
auto &run = logWS->mutableRun();
if (deleteExisting && run.hasProperty(name)) {
removeExisting(logWS, name);
}
createOrUpdate(run, name);
auto dtv = boost::make_shared<DateTimeValidator>();
}
/**
* Removes an existing instance of the log from the Workspace
* @param logWS The workspace containing the log
* @param name The name of the log to delete
*/
void AddNote::removeExisting(API::MatrixWorkspace_sptr &logWS,
const std::string &name) {
auto deleter = createChildAlgorithm("DeleteLog", -1, -1, false);
deleter->setProperty("Workspace", logWS);
deleter->setProperty("Name", name);
deleter->executeAsChildAlg();
}
/**
* Obtains variables to use in createOrUpdateValue function
* @param run The run object that either has the log or will store it
* @param name The name of the log to create/update
*/
void AddNote::createOrUpdate(API::Run &run, const std::string &name) {
std::string time = getProperty("Time");
if (time.empty()) {
namespace pt = boost::posix_time;
auto dateTimeObj = DateAndTime(pt::second_clock::local_time());
time = dateTimeObj.toISO8601String();
}
std::string value = getProperty("Value");
createOrUpdateValue(run, name, time, value);
}
} // namespace Algorithms
} // namespace Mantid