void MainWindow::on_actionAbout_triggered() { GSList *l; struct sr_dev_driver **drivers; struct sr_input_format **inputs; struct sr_output_format **outputs; struct srd_decoder *dec; QString s = tr("%1 %2<br />%3<br /><a href=\"%4\">%4</a>\n<p>") .arg(QApplication::applicationName()) .arg(QApplication::applicationVersion()) .arg(tr("GNU GPL, version 2 or later")) .arg(QApplication::organizationDomain()); s.append("<b>" + tr("Supported hardware drivers:") + "</b><table>"); drivers = sr_driver_list(); for (int i = 0; drivers[i]; ++i) { s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(drivers[i]->name)) .arg(QString(drivers[i]->longname))); } s.append("</table><p>"); s.append("<b>" + tr("Supported input formats:") + "</b><table>"); inputs = sr_input_list(); for (int i = 0; inputs[i]; ++i) { s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(inputs[i]->id)) .arg(QString(inputs[i]->description))); } s.append("</table><p>"); s.append("<b>" + tr("Supported output formats:") + "</b><table>"); outputs = sr_output_list(); for (int i = 0; outputs[i]; ++i) { s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(outputs[i]->id)) .arg(QString(outputs[i]->description))); } s.append("</table><p>"); s.append("<b>" + tr("Supported protocol decoders:") + "</b><table>"); for (l = srd_decoder_list(); l; l = l->next) { dec = (struct srd_decoder *)l->data; s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(dec->id)) .arg(QString(dec->longname))); } s.append("</table>"); QMessageBox::about(this, tr("About"), s); }
static void show_version(void) { GSList *l; struct sr_dev_driver **drivers; struct sr_input_format **inputs; struct sr_output_format **outputs; struct srd_decoder *dec; int i; printf("sigrok-cli %s\n\n", VERSION); printf("Using libsigrok %s (lib version %s).\n", sr_package_version_string_get(), sr_lib_version_string_get()); printf("Using libsigrokdecode %s (lib version %s).\n\n", srd_package_version_string_get(), srd_lib_version_string_get()); printf("Supported hardware drivers:\n"); drivers = sr_driver_list(); for (i = 0; drivers[i]; i++) { printf(" %-20s %s\n", drivers[i]->name, drivers[i]->longname); } printf("\n"); printf("Supported input formats:\n"); inputs = sr_input_list(); for (i = 0; inputs[i]; i++) printf(" %-20s %s\n", inputs[i]->id, inputs[i]->description); printf("\n"); printf("Supported output formats:\n"); outputs = sr_output_list(); for (i = 0; outputs[i]; i++) printf(" %-20s %s\n", outputs[i]->id, outputs[i]->description); printf("\n"); if (srd_init(NULL) == SRD_OK) { printf("Supported protocol decoders:\n"); srd_decoder_load_all(); for (l = srd_decoder_list(); l; l = l->next) { dec = l->data; printf(" %-20s %s\n", dec->id, dec->longname); /* Print protocol description upon "-l 3" or higher. */ if (opt_loglevel >= SR_LOG_INFO) printf(" %-20s %s\n", "", dec->desc); } srd_exit(); } printf("\n"); }
/** * Return the input file format which the CLI tool should use. * * If the user specified -I / --input-format, use that one. Otherwise, try to * autodetect the format as good as possible. Failing that, return NULL. * * @param filename The filename of the input file. Must not be NULL. * @param opt The -I / --input-file option the user specified (or NULL). * * @return A pointer to the 'struct sr_input_format' that should be used, * or NULL if no input format was selected or auto-detected. */ static struct sr_input_format *determine_input_file_format( const char *filename, const char *opt) { int i; struct sr_input_format **inputs; /* If there are no input formats, return NULL right away. */ inputs = sr_input_list(); if (!inputs) { g_critical("No supported input formats available."); return NULL; } /* If the user specified -I / --input-format, use that one. */ if (opt) { for (i = 0; inputs[i]; i++) { if (strcasecmp(inputs[i]->id, opt)) continue; g_debug("Using user-specified input file format '%s'.", inputs[i]->id); return inputs[i]; } /* The user specified an unknown input format, return NULL. */ g_critical("Error: specified input file format '%s' is " "unknown.", opt); return NULL; } /* Otherwise, try to find an input module that can handle this file. */ for (i = 0; inputs[i]; i++) { if (inputs[i]->format_match(filename)) break; } /* Return NULL if no input module wanted to touch this. */ if (!inputs[i]) { g_critical("Error: no matching input module found."); return NULL; } g_debug("cli: Autodetected '%s' input format for file '%s'.", inputs[i]->id, filename); return inputs[i]; }
/** * Sanity-check all libsigrok input modules. * * @return SR_OK if all modules are OK, SR_ERR if one or more have issues. */ static int sanity_check_all_input_modules(void) { int i, errors, ret = SR_OK; struct sr_input_format **inputs; const char *d; sr_spew("Sanity-checking all input modules."); inputs = sr_input_list(); for (i = 0; inputs[i]; i++) { errors = 0; d = (inputs[i]->id) ? inputs[i]->id : "NULL"; if (!inputs[i]->id) { sr_err("No ID in module %d ('%s').", i, d); errors++; } if (!inputs[i]->description) { sr_err("No description in module %d ('%s').", i, d); errors++; } if (!inputs[i]->format_match) { sr_err("No format_match in module %d ('%s').", i, d); errors++; } if (!inputs[i]->init) { sr_err("No init in module %d ('%s').", i, d); errors++; } if (!inputs[i]->loadfile) { sr_err("No loadfile in module %d ('%s').", i, d); errors++; } if (errors == 0) continue; ret = SR_ERR; } return ret; }
void show_version(void) { struct sr_dev_driver **drivers, *driver; struct sr_input_format **inputs, *input; struct sr_output_format **outputs, *output; const GSList *l; GSList *sl; int i; #ifdef HAVE_SRD struct srd_decoder *dec; #endif printf("sigrok-cli %s\n\n", VERSION); printf("Using libsigrok %s (lib version %s).\n", sr_package_version_string_get(), sr_lib_version_string_get()); #ifdef HAVE_SRD printf("Using libsigrokdecode %s (lib version %s).\n\n", srd_package_version_string_get(), srd_lib_version_string_get()); #endif printf("Supported hardware drivers:\n"); drivers = sr_driver_list(); for (sl = NULL, i = 0; drivers[i]; i++) sl = g_slist_append(sl, drivers[i]); sl = g_slist_sort(sl, sort_drivers); for (l = sl; l; l = l->next) { driver = l->data; printf(" %-20s %s\n", driver->name, driver->longname); } printf("\n"); g_slist_free(sl); printf("Supported input formats:\n"); inputs = sr_input_list(); for (sl = NULL, i = 0; inputs[i]; i++) sl = g_slist_append(sl, inputs[i]); sl = g_slist_sort(sl, sort_inputs); for (l = sl; l; l = l->next) { input = l->data; printf(" %-20s %s\n", input->id, input->description); } printf("\n"); g_slist_free(sl); printf("Supported output formats:\n"); outputs = sr_output_list(); for (sl = NULL, i = 0; outputs[i]; i++) sl = g_slist_append(sl, outputs[i]); sl = g_slist_sort(sl, sort_outputs); for (l = sl; l; l = l->next) { output = l->data; printf(" %-20s %s\n", output->id, output->description); } printf("\n"); g_slist_free(sl); #ifdef HAVE_SRD if (srd_init(NULL) == SRD_OK) { printf("Supported protocol decoders:\n"); srd_decoder_load_all(); sl = g_slist_copy((GSList *)srd_decoder_list()); sl = g_slist_sort(sl, sort_pds); for (l = sl; l; l = l->next) { dec = l->data; printf(" %-20s %s\n", dec->id, dec->longname); /* Print protocol description upon "-l 3" or higher. */ if (opt_loglevel >= SR_LOG_INFO) printf(" %-20s %s\n", "", dec->desc); } g_slist_free(sl); srd_exit(); } printf("\n"); #endif }
About::About(QWidget *parent) : QDialog(parent), ui(new Ui::About) { struct sr_dev_driver **drivers; struct sr_input_format **inputs; struct sr_output_format **outputs; #ifdef ENABLE_SIGROKDECODE struct srd_decoder *dec; #endif QString s; ui->setupUi(this); /* Setup the version field */ ui->versionInfo->setText(tr("%1 %2<br />%3<br /><a href=\"%4\">%4</a>") .arg(QApplication::applicationName()) .arg(QApplication::applicationVersion()) .arg(tr("GNU GPL, version 3 or later")) .arg(QApplication::organizationDomain())); ui->versionInfo->setOpenExternalLinks(true); s.append("<table>"); /* Set up the supported field */ s.append("<tr><td colspan=\"2\"><b>" + tr("Supported hardware drivers:") + "</b></td></tr>"); drivers = sr_driver_list(); for (int i = 0; drivers[i]; ++i) { s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(drivers[i]->name)) .arg(QString(drivers[i]->longname))); } s.append("<tr><td colspan=\"2\"><b>" + tr("Supported input formats:") + "</b></td></tr>"); inputs = sr_input_list(); for (int i = 0; inputs[i]; ++i) { s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(inputs[i]->id)) .arg(QString(inputs[i]->description))); } s.append("<tr><td colspan=\"2\"><b>" + tr("Supported output formats:") + "</b></td></tr>"); outputs = sr_output_list(); for (int i = 0; outputs[i]; ++i) { s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(outputs[i]->id)) .arg(QString(outputs[i]->description))); } #ifdef ENABLE_SIGROKDECODE s.append("<tr><td colspan=\"2\"><b>" + tr("Supported protocol decoders:") + "</b></td></tr>"); for (const GSList *l = srd_decoder_list(); l; l = l->next) { dec = (struct srd_decoder *)l->data; s.append(QString("<tr><td><i>%1</i></td><td>%2</td></tr>") .arg(QString(dec->id)) .arg(QString(dec->longname))); } #endif s.append("</table>"); supportedDoc.reset(new QTextDocument(this)); supportedDoc->setHtml(s); ui->supportList->setDocument(supportedDoc.get()); }