]> sigrok.org Git - pulseview.git/blobdiff - pv/mainwindow.hpp
MainWindow: Make session naming consistent
[pulseview.git] / pv / mainwindow.hpp
index 485b7b6df18243e8a7aa2085290639b86e6268e5..3cd269f4ff50c162e6868cddd6741a1f9fb91115 100644 (file)
@@ -57,6 +57,9 @@ class MainWindow : public QMainWindow
 {
        Q_OBJECT
 
+private:
+       static const QString WindowTitle;
+
 public:
        explicit MainWindow(DeviceManager &device_manager,
                std::string open_file_name = std::string(),
@@ -74,6 +77,10 @@ public:
        std::shared_ptr<pv::view::View> add_view(const QString &title,
                view::ViewType type, Session &session);
 
+       std::shared_ptr<Session> add_session();
+
+       void remove_session(std::shared_ptr<Session> session);
+
 private:
        void setup_ui();
 
@@ -89,6 +96,16 @@ private:
        virtual bool restoreState(const QByteArray &state, int version = 0);
 
 private Q_SLOTS:
+       void on_add_view(const QString &title, view::ViewType type,
+               Session *session);
+
+       void on_focus_changed();
+
+       void on_new_session();
+       void on_session_name_changed();
+       void on_new_view(Session *session);
+       void on_view_close_clicked();
+
        void on_actionViewStickyScrolling_triggered();
 
        void on_actionViewColouredBg_triggered();
@@ -98,13 +115,11 @@ private Q_SLOTS:
 private:
        DeviceManager &device_manager_;
 
-       Session session_;
+       std::list< std::shared_ptr<Session> > sessions_;
 
        std::map< std::shared_ptr<QDockWidget>,
                std::shared_ptr<pv::view::View> > view_docks_;
 
-       std::string open_file_name_, open_file_format_;
-
        QAction *const action_view_sticky_scrolling_;
        QAction *const action_view_coloured_bg_;
        QAction *const action_about_;