]> sigrok.org Git - pulseview.git/blobdiff - pv/mainwindow.h
Added empty context bar
[pulseview.git] / pv / mainwindow.h
index 47d3e66d0cad0efa131b7a72b4d796026966eb34..51577bdb742d9a53303ed260bfc77075e17a8aa8 100644 (file)
@@ -37,7 +37,10 @@ class QWidget;
 
 namespace pv {
 
+class DeviceManager;
+
 namespace toolbars {
+class ContextBar;
 class SamplingBar;
 }
 
@@ -50,15 +53,24 @@ class MainWindow : public QMainWindow
        Q_OBJECT
 
 public:
-       explicit MainWindow(const char *open_file_name = NULL,
+       explicit MainWindow(DeviceManager &device_manager,
+               const char *open_file_name = NULL,
                QWidget *parent = 0);
 
 private:
        void setup_ui();
-       void scan_devices();
 
        void session_error(const QString text, const QString info_text);
 
+       /**
+        * Updates the device list in the sampling bar, and updates the
+        * selection.
+        * @param selected_device The device to select, or NULL if the
+        * first device in the device list should be selected.
+        */
+       void update_device_list(
+               struct sr_dev_inst *selected_device = NULL);
+
 private slots:
        void load_file(QString file_name);
 
@@ -79,14 +91,16 @@ private slots:
 
        void on_actionAbout_triggered();
 
+       void device_selected();
+
        void run_stop();
 
        void capture_state_changed(int state);
 
 private:
+       DeviceManager &_device_manager;
 
        SigSession _session;
-       std::list<sr_dev_inst*> _devices;
 
        pv::view::View *_view;
 
@@ -109,6 +123,7 @@ private:
 
        QToolBar *_toolbar;
        toolbars::SamplingBar *_sampling_bar;
+       toolbars::ContextBar *_context_bar;
 };
 
 } // namespace pv