pqRecentFilesMenu.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: ParaView
4  Module: pqRecentFilesMenu.h
5 
6  Copyright (c) 2005-2008 Sandia Corporation, Kitware Inc.
7  All rights reserved.
8 
9  ParaView is a free software; you can redistribute it and/or modify it
10  under the terms of the ParaView license version 1.2.
11 
12  See License_v1.2.txt for the full ParaView license.
13  A copy of this license can be obtained by contacting
14  Kitware Inc.
15  28 Corporate Drive
16  Clifton Park, NY 12065
17  USA
18 
19 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR
23 CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
26 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
27 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 
31 =========================================================================*/
32 #ifndef pqRecentFilesMenu_h
33 #define pqRecentFilesMenu_h
34 
35 #include <QObject>
36 
37 #include "pqComponentsModule.h" // needed for export macros
38 #include <QPointer> // needed for QPointer
39 
40 class pqServer;
41 class pqServerResource;
42 class QAction;
43 class QMenu;
44 
63 class PQCOMPONENTS_EXPORT pqRecentFilesMenu : public QObject
64 {
65  Q_OBJECT
66 
67 public:
71  pqRecentFilesMenu(QMenu& menu, QObject* p = nullptr);
72  ~pqRecentFilesMenu() override;
73 
77  virtual bool open(pqServer* server, const pqServerResource& resource) const;
78 
86  void setSortByServers(bool val) { this->SortByServers = val; }
87  bool sortByServers() const { return this->SortByServers; }
88 
89 private Q_SLOTS:
90  void buildMenu();
91  void onOpenResource(QAction*);
92  void onOpenResource(const pqServerResource& resource);
93 
94 private: // NOLINT(readability-redundant-access-specifiers)
96  pqRecentFilesMenu& operator=(const pqRecentFilesMenu&);
97 
98  QPointer<QMenu> Menu;
99  bool SortByServers;
100 };
101 
102 #endif // !pqRecentFilesMenu_h
#define PQCOMPONENTS_EXPORT
bool sortByServers() const
manages recent files menu used in ParaView.
void setSortByServers(bool val)
When set to true (default), the menu is arranged to keep resources that use the same server together...
pqServerResource encapsulates a resource in ParaView.
pqServer (should be renamed to pqSession) is a pqServerManagerModelItem subclass that represents a vt...
Definition: pqServer.h:63