* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
-#ifdef ENABLE_SIGROKDECODE
#include <libsigrokdecode/libsigrokdecode.h>
-#endif
#include <boost/bind.hpp>
#include <boost/foreach.hpp>
#include "devicemanager.h"
#include "dialogs/about.h"
#include "dialogs/connect.h"
-#include "toolbars/contextbar.h"
#include "toolbars/samplingbar.h"
+#include "view/logicsignal.h"
#include "view/view.h"
+#include "widgets/decodermenu.h"
/* __STDC_FORMAT_MACROS is required for PRIu64 and friends (in C++). */
#define __STDC_FORMAT_MACROS
setCentralWidget(_central_widget);
_view = new pv::view::View(_session, this);
- connect(_view, SIGNAL(selection_changed()), this,
- SLOT(view_selection_changed()));
_vertical_layout->addWidget(_view);
"MainWindow", "Show &Cursors", 0, QApplication::UnicodeUTF8));
_menu_view->addAction(_action_view_show_cursors);
+ // Decoders Menu
+ _menu_decoders = new QMenu(_menu_bar);
+ _menu_decoders->setTitle(QApplication::translate(
+ "MainWindow", "&Decoders", 0, QApplication::UnicodeUTF8));
+
+ _menu_decoders_add = new pv::widgets::DecoderMenu(_menu_decoders);
+ _menu_decoders_add->setTitle(QApplication::translate(
+ "MainWindow", "&Add", 0, QApplication::UnicodeUTF8));
+ connect(_menu_decoders_add, SIGNAL(decoder_selected(srd_decoder*)),
+ this, SLOT(add_decoder(srd_decoder*)));
+
+ _menu_decoders->addMenu(_menu_decoders_add);
+
// Help Menu
_menu_help = new QMenu(_menu_bar);
_menu_help->setTitle(QApplication::translate(
_menu_bar->addAction(_menu_file->menuAction());
_menu_bar->addAction(_menu_view->menuAction());
+ _menu_bar->addAction(_menu_decoders->menuAction());
_menu_bar->addAction(_menu_help->menuAction());
setMenuBar(_menu_bar);
addToolBar(_toolbar);
// Setup the sampling bar
- _sampling_bar = new toolbars::SamplingBar(this);
+ _sampling_bar = new toolbars::SamplingBar(_session, this);
// Populate the device list and select the initially selected device
update_device_list();
- connect(_sampling_bar, SIGNAL(device_selected()), this,
- SLOT(device_selected()));
connect(_sampling_bar, SIGNAL(run_stop()), this,
SLOT(run_stop()));
addToolBar(_sampling_bar);
- // Setup the context bar
- _context_bar = new toolbars::ContextBar(this);
- addToolBar(_context_bar);
- insertToolBarBreak(_context_bar);
-
// Set the title
setWindowTitle(QApplication::translate("MainWindow", "PulseView", 0,
QApplication::UnicodeUTF8));
dlg.exec();
}
-void MainWindow::device_selected()
+void MainWindow::add_decoder(srd_decoder *decoder)
{
- _session.set_device(_sampling_bar->get_selected_device());
+ assert(decoder);
+ _session.add_decoder(decoder);
}
void MainWindow::run_stop()
_sampling_bar->set_capture_state((pv::SigSession::capture_state)state);
}
-void MainWindow::view_selection_changed()
-{
- assert(_context_bar);
-
- const list<weak_ptr<pv::view::SelectableItem> > items(
- _view->selected_items());
- _context_bar->set_selected_items(items);
-}
-
} // namespace pv