X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fdialogs%2Fsettings.cpp;h=8a3aef9c00a2103c86380f92a7c42df36d21cd3b;hp=0104b7c9e32f3de4c146c52ab6326e7fb8b68b9d;hb=669686c18ca6f1ee0697ae7804bfddf4fc6bd1e1;hpb=d008cab11b7508601e793d47e53a87be9972aed1 diff --git a/pv/dialogs/settings.cpp b/pv/dialogs/settings.cpp index 0104b7c9..8a3aef9c 100644 --- a/pv/dialogs/settings.cpp +++ b/pv/dialogs/settings.cpp @@ -17,6 +17,11 @@ * along with this program; if not, see . */ +#include "config.h" + +#include +#include + #include #include #include @@ -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("Used libraries:") + ""); + tr("Libraries and features:") + ""); + s.append(QString("%1%2") .arg(QString("Qt"), qVersion())); - s.append(QString("%1%2 (lib version %3)") - .arg(QString("libsigrok"), sr_package_version_string_get(), sr_lib_version_string_get())); + s.append(QString("%1%2") + .arg(QString("glibmm"), PV_GLIBMM_VERSION)); + s.append(QString("%1%2") + .arg(QString("Boost"), BOOST_LIB_VERSION)); + + s.append(QString("%1%2/%3 (rt: %4/%5)") + .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("- %1%2") + .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("- Host%1") + .arg(QString(host))); + g_free(host); + + char *scpi_backends = sr_buildinfo_scpi_backends_get(); + s.append(QString("- SCPI backends%1") + .arg(QString(scpi_backends))); + g_free(scpi_backends); + #ifdef ENABLE_DECODE - s.append(QString("%1%2 (lib version %3)") - .arg(QString("libsigrokdecode"), srd_package_version_string_get(), srd_lib_version_string_get())); + s.append(QString("%1%2/%3 (rt: %4/%5)") + .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("- %1%2") + .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("- Host%1") + .arg(QString(host))); + g_free(host); #endif /* Set up the supported field */ + s.append(""); s.append("" + tr("Supported hardware drivers:") + ""); 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(""); s.append("" + tr("Supported input formats:") + ""); 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(""); s.append("" + tr("Supported output formats:") + ""); for (auto entry : context->output_formats()) { @@ -223,6 +311,7 @@ QWidget *Settings::get_about_page(QWidget *parent) const } #ifdef ENABLE_DECODE + s.append(""); s.append("" + tr("Supported protocol decoders:") + ""); GSList *sl = g_slist_copy((GSList *)srd_decoder_list());