X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fdialogs%2Fsettings.cpp;h=e8e102c2c36d3a0c75858bae555c3e6479593571;hb=6579ca9227e50f8a3acd1a5d5364752864d2e7fd;hp=e221e5627c2b337c2dc797151a34947fa77844ee;hpb=8ad61f4071a69445a6917d214b6592878447ddb1;p=pulseview.git diff --git a/pv/dialogs/settings.cpp b/pv/dialogs/settings.cpp index e221e56..e8e102c 100644 --- a/pv/dialogs/settings.cpp +++ b/pv/dialogs/settings.cpp @@ -17,6 +17,8 @@ * along with this program; if not, see . */ +#include + #include #include #include @@ -148,6 +150,17 @@ QWidget *Settings::get_view_settings_form(QWidget *parent) const return form; } +#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 @@ -169,19 +182,50 @@ QWidget *Settings::get_about_page(QWidget *parent) const shared_ptr context = device_manager_.context(); QString s; + + s.append(""); + s.append(""); /* Library info */ s.append(""); + tr("Libraries and features:") + ""); s.append(QString("") .arg(QString("Qt"), qVersion())); + s.append(QString("") + .arg(QString("libsigrok"), 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("") + .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("") + .arg(QString(host))); + g_free(host); + + char *scpi_backends = sr_buildinfo_scpi_backends_get(); + s.append(QString("") + .arg(QString(scpi_backends))); + g_free(scpi_backends); + +#ifdef ENABLE_DECODE + s.append(QString("") + .arg(QString("libsigrokdecode"), srd_package_version_string_get(), srd_lib_version_string_get())); +#endif /* Set up the supported field */ s.append(""); for (auto entry : context->drivers()) { - s.append(QString("") + s.append(QString("") .arg(QString::fromUtf8(entry.first.c_str()), QString::fromUtf8(entry.second->long_name().c_str()))); } @@ -189,7 +233,7 @@ QWidget *Settings::get_about_page(QWidget *parent) const s.append(""); for (auto entry : context->input_formats()) { - s.append(QString("") + s.append(QString("") .arg(QString::fromUtf8(entry.first.c_str()), QString::fromUtf8(entry.second->description().c_str()))); } @@ -197,7 +241,7 @@ QWidget *Settings::get_about_page(QWidget *parent) const s.append(""); for (auto entry : context->output_formats()) { - s.append(QString("") + s.append(QString("") .arg(QString::fromUtf8(entry.first.c_str()), QString::fromUtf8(entry.second->description().c_str()))); } @@ -205,12 +249,15 @@ QWidget *Settings::get_about_page(QWidget *parent) const #ifdef ENABLE_DECODE s.append(""); - for (const GSList *l = srd_decoder_list(); l; l = l->next) { + 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("") + s.append(QString("") .arg(QString::fromUtf8(dec->id), QString::fromUtf8(dec->longname))); } + g_slist_free(sl); #endif s.append("
" + - tr("Used libraries:") + "
%1%2
%1%2 (lib version %3)
- %1%2
- Host%1
- SCPI backends%1
%1%2 (lib version %3)
" + tr("Supported hardware drivers:") + "
%1%2
%1%2
" + tr("Supported input formats:") + "
%1%2
%1%2
" + tr("Supported output formats:") + "
%1%2
%1%2
" + tr("Supported protocol decoders:") + "
%1%2
%1%2
");