]> sigrok.org Git - pulseview.git/blobdiff - pv/dialogs/settings.cpp
Settings: Add decoder settings page
[pulseview.git] / pv / dialogs / settings.cpp
index 0104b7c9e32f3de4c146c52ab6326e7fb8b68b9d..8a3aef9c00a2103c86380f92a7c42df36d21cd3b 100644 (file)
  * along with this program; if not, see <http://www.gnu.org/licenses/>.
  */
 
+#include "config.h"
+
+#include <glib.h>
+#include <boost/version.hpp>
+
 #include <QApplication>
 #include <QCheckBox>
 #include <QDialogButtonBox>
@@ -96,6 +101,17 @@ void Settings::create_pages()
        viewButton->setTextAlignment(Qt::AlignHCenter);
        viewButton->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
 
+#ifdef ENABLE_DECODE
+       // Decoder page
+       pages->addWidget(get_decoder_settings_form(pages));
+
+       QListWidgetItem *decoderButton = new QListWidgetItem(page_list);
+       decoderButton->setIcon(QIcon(":/icons/add-decoder.svg"));
+       decoderButton->setText(tr("Decoders"));
+       decoderButton->setTextAlignment(Qt::AlignHCenter);
+       decoderButton->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
+#endif
+
        // About page
        pages->addWidget(get_about_page(pages));
 
@@ -148,6 +164,27 @@ QWidget *Settings::get_view_settings_form(QWidget *parent) const
        return form;
 }
 
+QWidget *Settings::get_decoder_settings_form(QWidget *parent) const
+{
+#ifdef ENABLE_DECODE
+       GlobalSettings settings;
+
+       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);
+
+       return form;
+#else
+       (void)parent;
+#endif
+}
+
 #ifdef ENABLE_DECODE
 static gint sort_pds(gconstpointer a, gconstpointer b)
 {
@@ -187,17 +224,66 @@ QWidget *Settings::get_about_page(QWidget *parent) const
 
        /* Library info */
        s.append("<tr><td colspan=\"2\"><b>" +
-               tr("Used libraries:") + "</b></td></tr>");
+               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 (lib version %3)</td></tr>")
-               .arg(QString("libsigrok"), sr_package_version_string_get(), sr_lib_version_string_get()));
+       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 (lib version %3)</td></tr>")
-               .arg(QString("libsigrokdecode"), srd_package_version_string_get(), srd_lib_version_string_get()));
+       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
 
        /* 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()) {
@@ -206,6 +292,7 @@ QWidget *Settings::get_about_page(QWidget *parent) const
                                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()) {
@@ -214,6 +301,7 @@ QWidget *Settings::get_about_page(QWidget *parent) const
                                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()) {
@@ -223,6 +311,7 @@ QWidget *Settings::get_about_page(QWidget *parent) const
        }
 
 #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());