This file is indexed.

/usr/include/OpenMS/VISUAL/TOPPASScene.h is in libopenms-dev 1.11.1-5.

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