/usr/include/OpenMS/VISUAL/TOPPASScene.h is in libopenms-dev 1.11.1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 | // --------------------------------------------------------------------------
// OpenMS -- Open-Source Mass Spectrometry
// --------------------------------------------------------------------------
// Copyright The OpenMS Team -- Eberhard Karls University Tuebingen,
// ETH Zurich, and Freie Universitaet Berlin 2002-2013.
//
// This software is released under a three-clause BSD license:
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
// * Neither the name of any author or any participating institution
// may be used to endorse or promote products derived from this software
// without specific prior written permission.
// For a full list of authors, refer to the file AUTHORS.
// --------------------------------------------------------------------------
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL ANY OF THE AUTHORS OR THE CONTRIBUTING
// INSTITUTIONS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
// --------------------------------------------------------------------------
// $Maintainer: Johannes Junker $
// $Authors: Johannes Junker, Chris Bielow $
// --------------------------------------------------------------------------
#ifndef OPENMS_VISUAL_TOPPASSCENE_H
#define OPENMS_VISUAL_TOPPASSCENE_H
#include <OpenMS/config.h>
#include <OpenMS/VISUAL/TOPPASEdge.h>
#include <OpenMS/DATASTRUCTURES/String.h>
#include <OpenMS/VISUAL/TOPPASToolVertex.h>
#include <QtGui/QGraphicsScene>
#include <QtCore/QProcess>
namespace OpenMS
{
class TOPPASVertex;
class TOPPASToolVertex;
class TOPPASMergerVertex;
class TOPPASOutputFileListVertex;
class TOPPASEdge;
class TOPPASResources;
/**
@brief A FakeProcess class.
*/
class FakeProcess :
public QProcess
{
Q_OBJECT
public:
virtual void start(const QString & program, const QStringList & arguments, OpenMode mode = ReadWrite);
};
/**
@brief A container for all visual items of a TOPPAS workflow
TOPPASScene is a subclass of QGraphicsScene and acts as a container for all visual items
(i.e. all vertices and edges). It is visualized by a TOPPASWidget (a subclass of QGraphicsView).
This class also provides large parts of the functionality of TOPPAS, e.g., the methods for loading,
saving, running, and aborting pipelines are located here.
TOPPASScene can also be used without a visualizing TOPPASWidget (i.e., without a gui) which can
be indicated via the constructor. In this case, the signals for log message output are connected
to standard out. This is utilized for the ExecutePipeline tool.
Temporary files of the pipeline are stored in the member tmp_path_. Update it when loading a pipeline which has
tmp data from an old run. TOPPASToolVertex will ask its parent scene() whenever it wants to know the tmp directory.
@ingroup TOPPAS_elements
*/
class OPENMS_GUI_DLLAPI TOPPASScene :
public QGraphicsScene
{
Q_OBJECT
public:
/// Stores the information for a TOPP process
struct TOPPProcess
{
/// Constructor
TOPPProcess(QProcess * p, const QString & cmd, const QStringList & arg, TOPPASToolVertex * const tool) :
proc(p),
command(cmd),
args(arg),
tv(tool)
{
}
/// The process
QProcess * proc;
/// The command
QString command;
/// The arguments
QStringList args;
/// The tool which is started (used to call its slots)
TOPPASToolVertex * tv;
};
/// The current action mode (creation of a new edge, or panning of the widget)
enum ActionMode
{
AM_NEW_EDGE,
AM_MOVE
};
/// Pipeline status after refreshParameters() was called
enum RefreshStatus
{
ST_REFRESH_NOCHANGE, //< no updates required
ST_REFRESH_CHANGED, //< some parameters were updated, but pipeline is ok
ST_REFRESH_CHANGEINVALID, //< updating made pipeline invalid
ST_REFRESH_REMAINSINVALID //< pipeline was not valid before and is invalid afterwards
};
/// The container for edges
typedef QList<TOPPASEdge *> EdgeContainer;
/// A mutable iterator for edges
typedef EdgeContainer::iterator EdgeIterator;
/// A const iterator for edges
typedef EdgeContainer::const_iterator ConstEdgeIterator;
/// The container for vertices
typedef QList<TOPPASVertex *> VertexContainer;
/// A mutable iterator for vertices
typedef VertexContainer::iterator VertexIterator;
/// A const iterator for vertices
typedef VertexContainer::const_iterator ConstVertexIterator;
/// Constructor
TOPPASScene(QObject * parent, const QString & tmp_path, bool gui = true);
/// Destructor
virtual ~TOPPASScene();
/// Adds a vertex
void addVertex(TOPPASVertex * tv);
/// Adds an edge
void addEdge(TOPPASEdge * te);
/// Sets the action mode
void setActionMode(ActionMode mode);
/// Returns the action mode
ActionMode getActionMode();
/// Returns begin() iterator of all vertices
VertexIterator verticesBegin();
/// Returns end() iterator of all vertices
VertexIterator verticesEnd();
/// Returns begin() iterator of all edges
EdgeIterator edgesBegin();
/// Returns end() iterator of all edges
EdgeIterator edgesEnd();
/// Copies all currently selected edges and vertices
void copySelected();
/// Pastes the copied items
void paste(QPointF pos = QPointF());
/// Removes all currently selected edges and vertices
void removeSelected();
/// Unselects all items
void unselectAll();
/// Updates all edge colors (color of green and yellow edges can change when edges are added/removed)
void updateEdgeColors();
/// Called when user fires "Resume" action, to clear downstream nodes from previous results
void resetDownstream(TOPPASVertex * vertex);
/// Runs the pipeline
void runPipeline();
/// Stores the pipeline to @p file, returns true on success
bool store(const String & file);
/// Loads the pipeline from @p file
void load(const String & file);
/// Includes the pipeline @p scene
void include(TOPPASScene * new_scene, QPointF pos = QPointF());
/// Returns the file name
const String & getSaveFileName();
/// Sets the file name
void setSaveFileName(const String & name);
/// Performs a topological sort of all vertices
void topoSort();
/// Returns the name of the directory for output files
const QString & getOutDir();
/// Returns the name of the directory for temporary files
const QString & getTempDir();
/// Sets the name of the directory for output files
void setOutDir(const QString & dir);
/// Saves the pipeline if it has been changed since the last save.
bool saveIfChanged();
/// Sets the changed flag
void setChanged(bool b);
/// Returns if a pipeline is currently running
bool isPipelineRunning();
/// Shows a dialog that allows to specify the output directory. If @p always_ask == false, the dialog won't be shown if a directory has been set, already.
bool askForOutputDir(bool always_ask = true);
/// Enqueues the process, it will be run when the currently pending processes have finished
void enqueueProcess(const TOPPProcess & process);
/// Runs the next process in the queue, if any
void runNextProcess();
/// Resets the processes queue
void resetProcessesQueue();
/// Sets the clipboard content
void setClipboard(TOPPASScene * clipboard);
///Connects the signals to slots
void connectVertexSignals(TOPPASVertex * tv);
///Connects the signals to slots
void connectToolVertexSignals(TOPPASToolVertex * ttv);
///Connects the signals to slots
void connectOutputVertexSignals(TOPPASOutputFileListVertex * oflv);
///Connects the signals to slots
void connectMergerVertexSignals(TOPPASMergerVertex * tmv);
///Connects the signals to slots
void connectEdgeSignals(TOPPASEdge * e);
///Loads the @p resources into the input nodes of this workflow
void loadResources(const TOPPASResources & resources);
///Create @p resources from the current workflow
void createResources(TOPPASResources & resources);
///Returns whether the workflow has been changed since the latest "save"
bool wasChanged();
/// Refreshes the parameters of the TOPP tools in this workflow
RefreshStatus refreshParameters();
/// determine dry run status (are tools actually called?)
bool isDryRun() const;
/// workflow description (to be displayed in TOPPAS window)
QString getDescription() const;
/// when description is updated by user, use this to update the description for later storage in file
void setDescription(const QString & desc);
/// sets the maximum number of jobs
void setAllowedThreads(int num_threads);
/// returns the hovering edge
TOPPASEdge* getHoveringEdge();
/// Checks whether all output vertices are finished, and if yes, emits entirePipelineFinished() (called by finished output vertices)
void checkIfWeAreDone();
public slots:
/// Terminates the currently running pipeline
void abortPipeline();
/// Called when an item is clicked
void itemClicked();
/// Called when an item is released
void itemReleased();
/// Called when the position of the hovering edge changes
void updateHoveringEdgePos(const QPointF & new_pos);
/// Called when a new out edge is supposed to be created
void addHoveringEdge(const QPointF & pos);
/// Called when the new edge is being "released"
void finishHoveringEdge();
/// Called by vertices at which an error occurred during pipeline execution
void pipelineErrorSlot(const QString msg = "");
/// Moves all selected items by dx, dy
void moveSelectedItems(qreal dx, qreal dy);
/// Makes all vertices snap to the grid
void snapToGrid();
/// Sets if the running_ flag to true, or false
/// If set to false, the application emits an 'alert' sign, demanding user attention (to let him know it finished)
void setPipelineRunning(bool b = true);
/// Invoked by TTV or other vectices if a parameter was edited
void changedParameter(const bool invalidates_running_pipeline);
/// Called by a finished QProcess to indicate that we are free to start a new one
void processFinished();
/// dirty solution: when using ExecutePipeline this slot is called when the pipeline crashes. This will quit the app
void quitWithError();
///@name Slots for printing log/error output when no GUI is available
//@{
/// Writes the TOPP tool output to the logfile (and to stdout if no gui available)
void logTOPPOutput(const QString & out);
/// Writes the "tool started" message to the logfile (and to stdout if no gui available)
void logToolStarted();
/// Writes the "tool finished" message to the logfile (and to stdout if no gui available)
void logToolFinished();
/// Writes the "tool failed" message to the logfile (and to stdout if no gui available)
void logToolFailed();
/// Writes the "tool crashed" message to the logfile (and to stdout if no gui available)
void logToolCrashed();
/// Writes the "output file written" message to the logfile (and to stdout if no gui available)
void logOutputFileWritten(const String & file);
//@}
signals:
/// Emitted when the entire pipeline execution is finished
void entirePipelineFinished();
/// Emitted when the pipeline execution has failed
void pipelineExecutionFailed();
/// Emitted when the pipeline should be saved (showing a save as file dialog and so on)
void saveMe();
/// Kills all connected TOPP processes
void terminateCurrentPipeline();
/// Emitted when a selection is copied to the clipboard
void selectionCopied(TOPPASScene * ts);
/// Requests the clipboard content from TOPPASBase, will be stored in clipboard_
void requestClipboardContent();
/// Emitted when the main window needs to be updated
void mainWindowNeedsUpdate();
/// Emitted when files are triggered for opening in TOPPView
void openInTOPPView(QStringList all_files);
/// Emitted when in dry run mode and asked to run a TOPP tool (to fake success)
void dryRunFinished(int, QProcess::ExitStatus);
/// Emitted when there is an important message that needs to be printed in TOPPAS
void messageReady(const QString & msg);
protected:
/// The current action mode
ActionMode action_mode_;
/// The list of all vertices
VertexContainer vertices_;
/// The list of all edges
EdgeContainer edges_;
/// The hovering edge which is currently being created
TOPPASEdge * hover_edge_;
/// The current potential target vertex of the hovering edge
TOPPASVertex * potential_target_;
/// The file name of this pipeline
String file_name_;
/// The path for temporary files
QString tmp_path_;
/// Are we in a GUI or is the scene used by ExecutePipeline (at the command line)?
bool gui_;
/// The directory where the output files will be written
QString out_dir_;
/// Flag that indicates if the pipeline has been changed since the last save
bool changed_;
/// Indicates if a pipeline is currently running
bool running_;
/// true if an error occurred during pipeline execution
bool error_occured_;
/// Indicates if the output directory has been specified by the user already
bool user_specified_out_dir_;
/// The queue of pending TOPP processes
QList<TOPPProcess> topp_processes_queue_;
/// Stores the clipboard content when requested from TOPPASBase
TOPPASScene * clipboard_;
/// dry run mode (no tools are actually called)
bool dry_run_;
/// currently running processes...
int threads_active_;
/// description text
QString description_text_;
/// maximum number of allowed threads
int allowed_threads_;
/// last node where 'resume' was started
TOPPASToolVertex* resume_source_;
/// Returns the vertex in the foreground at position @p pos , if existent, otherwise 0.
TOPPASVertex * getVertexAt_(const QPointF & pos);
/// Returns whether an edge between node u and v would be allowed
bool isEdgeAllowed_(TOPPASVertex * u, TOPPASVertex * v);
/// DFS helper method. Returns true, if a back edge has been discovered
bool dfsVisit_(TOPPASVertex * vertex);
/// Performs a sanity check of the pipeline and notifies user when it finds something strange. Returns if pipeline OK.
/// if 'allowUserOverride' is true, some dialogs are shown which allow the user to ignore some warnings (e.g. disconnected nodes)
bool sanityCheck_(bool allowUserOverride);
///@name reimplemented Qt events
//@{
void contextMenuEvent(QGraphicsSceneContextMenuEvent * event);
//@}
///Writes the @p text to the logfile
void writeToLogFile_(const QString & text);
};
}
#endif
|