+QWidget *Settings::get_decoder_settings_form(QWidget *parent) const
+{
+#ifdef ENABLE_DECODE
+ QCheckBox *cb;
+
+ QWidget *form = new QWidget(parent);
+ QVBoxLayout *form_layout = new QVBoxLayout(form);
+
+ // Decoder settings
+ QGroupBox *decoder_group = new QGroupBox(tr("Decoders"));
+ form_layout->addWidget(decoder_group);
+
+ QFormLayout *decoder_layout = new QFormLayout();
+ decoder_group->setLayout(decoder_layout);
+
+ cb = create_checkbox(GlobalSettings::Key_Dec_InitialStateConfigurable,
+ SLOT(on_dec_initialStateConfigurable_changed(int)));
+ decoder_layout->addRow(tr("Allow configuration of &initial signal state"), cb);
+
+ return form;
+#else
+ (void)parent;
+ return nullptr;
+#endif
+}
+
+#ifdef ENABLE_DECODE
+static gint sort_pds(gconstpointer a, gconstpointer b)
+{
+ const struct srd_decoder *sda, *sdb;
+
+ sda = (const struct srd_decoder *)a;
+ sdb = (const struct srd_decoder *)b;
+ return strcmp(sda->id, sdb->id);
+}
+#endif
+
+QWidget *Settings::get_about_page(QWidget *parent) const
+{
+#ifdef ENABLE_DECODE
+ struct srd_decoder *dec;
+#endif
+
+ QLabel *icon = new QLabel();
+ icon->setPixmap(QPixmap(QString::fromUtf8(":/icons/pulseview.svg")));
+
+ /* Setup the version field */
+ QLabel *version_info = new QLabel();
+ version_info->setText(tr("%1 %2<br />%3<br /><a href=\"http://%4\">%4</a>")
+ .arg(QApplication::applicationName(),
+ QApplication::applicationVersion(),
+ tr("GNU GPL, version 3 or later"),
+ QApplication::organizationDomain()));
+ version_info->setOpenExternalLinks(true);
+
+ shared_ptr<sigrok::Context> context = device_manager_.context();
+
+ QString s;
+
+ s.append("<style type=\"text/css\"> tr .id { white-space: pre; padding-right: 5px; } </style>");
+
+ s.append("<table>");
+
+ /* Library info */
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Libraries and features:") + "</b></td></tr>");
+
+ s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString("Qt"), qVersion()));
+ s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString("glibmm"), PV_GLIBMM_VERSION));
+ s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString("Boost"), BOOST_LIB_VERSION));
+
+ s.append(QString("<tr><td><i>%1</i></td><td>%2/%3 (rt: %4/%5)</td></tr>")
+ .arg(QString("libsigrok"), SR_PACKAGE_VERSION_STRING,
+ SR_LIB_VERSION_STRING, sr_package_version_string_get(),
+ sr_lib_version_string_get()));
+
+ GSList *l_orig = sr_buildinfo_libs_get();
+ for (GSList *l = l_orig; l; l = l->next) {
+ GSList *m = (GSList *)l->data;
+ const char *lib = (const char *)m->data;
+ const char *version = (const char *)m->next->data;
+ s.append(QString("<tr><td><i>- %1</i></td><td>%2</td></tr>")
+ .arg(QString(lib), QString(version)));
+ g_slist_free_full(m, g_free);
+ }
+ g_slist_free(l_orig);
+
+ char *host = sr_buildinfo_host_get();
+ s.append(QString("<tr><td><i>- Host</i></td><td>%1</td></tr>")
+ .arg(QString(host)));
+ g_free(host);
+
+ char *scpi_backends = sr_buildinfo_scpi_backends_get();
+ s.append(QString("<tr><td><i>- SCPI backends</i></td><td>%1</td></tr>")
+ .arg(QString(scpi_backends)));
+ g_free(scpi_backends);
+
+#ifdef ENABLE_DECODE
+ s.append(QString("<tr><td><i>%1</i></td><td>%2/%3 (rt: %4/%5)</td></tr>")
+ .arg(QString("libsigrokdecode"), SRD_PACKAGE_VERSION_STRING,
+ SRD_LIB_VERSION_STRING, srd_package_version_string_get(),
+ srd_lib_version_string_get()));
+
+ l_orig = srd_buildinfo_libs_get();
+ for (GSList *l = l_orig; l; l = l->next) {
+ GSList *m = (GSList *)l->data;
+ const char *lib = (const char *)m->data;
+ const char *version = (const char *)m->next->data;
+ s.append(QString("<tr><td><i>- %1</i></td><td>%2</td></tr>")
+ .arg(QString(lib), QString(version)));
+ g_slist_free_full(m, g_free);
+ }
+ g_slist_free(l_orig);
+
+ host = srd_buildinfo_host_get();
+ s.append(QString("<tr><td><i>- Host</i></td><td>%1</td></tr>")
+ .arg(QString(host)));
+ g_free(host);
+#endif
+
+ s.append("<tr><td colspan=\"2\"></td></tr>");
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Firmware search paths:") + "</b></td></tr>");
+
+ l_orig = sr_resourcepaths_get(SR_RESOURCE_FIRMWARE);
+ for (GSList *l = l_orig; l; l = l->next)
+ s.append(QString("<tr><td colspan=\"2\">%1</td></tr>").arg(
+ QString((char*)l->data)));
+ g_slist_free_full(l_orig, g_free);
+
+#ifdef ENABLE_DECODE
+ s.append("<tr><td colspan=\"2\"></td></tr>");
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Protocol decoder search paths:") + "</b></td></tr>");
+
+ l_orig = srd_searchpaths_get();
+ for (GSList *l = l_orig; l; l = l->next)
+ s.append(QString("<tr><td colspan=\"2\">%1</td></tr>").arg(
+ QString((char*)l->data)));
+ g_slist_free_full(l_orig, g_free);
+#endif
+
+ /* Set up the supported field */
+ s.append("<tr><td colspan=\"2\"></td></tr>");
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Supported hardware drivers:") + "</b></td></tr>");
+ for (auto entry : context->drivers()) {
+ s.append(QString("<tr><td class=\"id\"><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString::fromUtf8(entry.first.c_str()),
+ QString::fromUtf8(entry.second->long_name().c_str())));
+ }
+
+ s.append("<tr><td colspan=\"2\"></td></tr>");
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Supported input formats:") + "</b></td></tr>");
+ for (auto entry : context->input_formats()) {
+ s.append(QString("<tr><td class=\"id\"><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString::fromUtf8(entry.first.c_str()),
+ QString::fromUtf8(entry.second->description().c_str())));
+ }
+
+ s.append("<tr><td colspan=\"2\"></td></tr>");
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Supported output formats:") + "</b></td></tr>");
+ for (auto entry : context->output_formats()) {
+ s.append(QString("<tr><td class=\"id\"><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString::fromUtf8(entry.first.c_str()),
+ QString::fromUtf8(entry.second->description().c_str())));
+ }
+
+#ifdef ENABLE_DECODE
+ s.append("<tr><td colspan=\"2\"></td></tr>");
+ s.append("<tr><td colspan=\"2\"><b>" +
+ tr("Supported protocol decoders:") + "</b></td></tr>");
+ GSList *sl = g_slist_copy((GSList *)srd_decoder_list());
+ sl = g_slist_sort(sl, sort_pds);
+ for (const GSList *l = sl; l; l = l->next) {
+ dec = (struct srd_decoder *)l->data;
+ s.append(QString("<tr><td class=\"id\"><i>%1</i></td><td>%2</td></tr>")
+ .arg(QString::fromUtf8(dec->id),
+ QString::fromUtf8(dec->longname)));
+ }
+ g_slist_free(sl);
+#endif
+
+ s.append("</table>");
+
+ QTextDocument *supported_doc = new QTextDocument();
+ supported_doc->setHtml(s);
+
+ QTextBrowser *support_list = new QTextBrowser();
+ support_list->setDocument(supported_doc);
+
+ QGridLayout *layout = new QGridLayout();
+ layout->addWidget(icon, 0, 0, 1, 1);
+ layout->addWidget(version_info, 0, 1, 1, 1);
+ layout->addWidget(support_list, 1, 1, 1, 1);
+
+ QWidget *page = new QWidget(parent);
+ page->setLayout(layout);
+
+ return page;
+}
+
+QWidget *Settings::get_logging_page(QWidget *parent) const
+{
+ GlobalSettings settings;
+
+ // Log level
+ QSpinBox *loglevel_sb = new QSpinBox();
+ loglevel_sb->setMaximum(SR_LOG_SPEW);
+ loglevel_sb->setValue(logging.get_log_level());
+ connect(loglevel_sb, SIGNAL(valueChanged(int)), this,
+ SLOT(on_log_logLevel_changed(int)));
+
+ QHBoxLayout *loglevel_layout = new QHBoxLayout();
+ loglevel_layout->addWidget(new QLabel(tr("Log level:")));
+ loglevel_layout->addWidget(loglevel_sb);
+
+ // Background buffer size
+ QSpinBox *buffersize_sb = new QSpinBox();
+ buffersize_sb->setSuffix(tr(" lines"));
+ buffersize_sb->setMaximum(Logging::MAX_BUFFER_SIZE);
+ buffersize_sb->setValue(
+ settings.value(GlobalSettings::Key_Log_BufferSize).toInt());
+ connect(buffersize_sb, SIGNAL(valueChanged(int)), this,
+ SLOT(on_log_bufferSize_changed(int)));
+
+ QHBoxLayout *buffersize_layout = new QHBoxLayout();
+ buffersize_layout->addWidget(new QLabel(tr("Length of background buffer:")));
+ buffersize_layout->addWidget(buffersize_sb);
+
+ // Save to file
+ QPushButton *save_log_pb = new QPushButton(
+ QIcon::fromTheme("document-save-as", QIcon(":/icons/document-save-as.png")),
+ tr("&Save to File"));
+ connect(save_log_pb, SIGNAL(clicked(bool)),
+ this, SLOT(on_log_saveToFile_clicked(bool)));
+
+ // Pop out
+ QPushButton *pop_out_pb = new QPushButton(
+ QIcon::fromTheme("window-new", QIcon(":/icons/window-new.png")),
+ tr("&Pop out"));
+ connect(pop_out_pb, SIGNAL(clicked(bool)),
+ this, SLOT(on_log_popOut_clicked(bool)));
+
+ QHBoxLayout *control_layout = new QHBoxLayout();
+ control_layout->addLayout(loglevel_layout);
+ control_layout->addLayout(buffersize_layout);
+ control_layout->addWidget(save_log_pb);
+ control_layout->addWidget(pop_out_pb);
+
+ QVBoxLayout *root_layout = new QVBoxLayout();
+ root_layout->addLayout(control_layout);
+ root_layout->addWidget(log_view_);
+
+ QWidget *page = new QWidget(parent);
+ page->setLayout(root_layout);
+
+ return page;
+}
+