SHA256
1
0
forked from pool/alsa-utils
alsa-utils/0013-alsatplg-add-n-normalize-option.patch
Takashi Iwai 7200ea9d85 Accepting request 766332 from home:tiwai:branches:multimedia:libs
- Backport upstream patches:
  A few portability fixes, alsaucm fixes and extensions, alsatplg
  minor fixes, alsa-info.sh extensions:
  0001-treewide-sys-poll-to-poll.patch
  0002-treewide-Fix-wrong-formats-on-32-bit.patch
  0003-treewide-Fix-printf-formats.patch
  0004-aplay-Adjust-buffer-sizes-to-fix-snprintf-warnings.patch
  0005-aplay-Limit-VUMeter-progress-bar-to-100-for-negative.patch
  0006-alsactl-sysfs-add-sys-kernel-uevent_seqnum-check-to-.patch
  0007-alsaucm-use-the-first-sound-card-use-case-name-hw-CA.patch
  0008-alsaucm-add-text-dump-command.patch
  0009-alsaucm-add-json-dump-command.patch
  0010-alsaucm-dump-fix-the-prefixed.patch
  0011-alsactl-fix-sched-idle-set-it-really-to-SCHED_IDLE.patch
  0012-configure-Fix-linking-of-alsatplg-with-the-older-lib.patch
  0013-alsatplg-add-n-normalize-option.patch
  0014-alsatplg-add-s-sort-and-fix-memory-leaks.patch
  0015-alsatplg-fix-another-small-leak-in-normalize_config.patch
  0016-alsa-info.sh-Consolidate-PCI-device-output.patch
  0017-alsa-info.sh-Read-from-proc-modules-and-sort-the-res.patch
  0018-alsa-info.sh-Simplify-iteration-over-cards-when-call.patch
  0019-alsa-info.sh-Use-existing-function-to-print-ALSA-con.patch
  0020-alsa-info.sh-Exit-script-after-writing-information-t.patch
  0021-alsa-info.sh-Replace-gauge-with-infobox-for-upload-d.patch
  0022-alsa-info.sh-Remove-progress-spinner-during-upload-w.patch
  0023-alsa-info.sh-Condense-nested-commands-for-file-uploa.patch
  0024-alsa-info.sh-Condense-nested-commands-for-formatting.patch
  0025-alsa-info.sh-Perform-test-for-wget-earlier.patch
  0026-alsa-info.sh-Warn-after-actual-upload-failure-do-not.patch

OBS-URL: https://build.opensuse.org/request/show/766332
OBS-URL: https://build.opensuse.org/package/show/multimedia:libs/alsa-utils?expand=0&rev=165
2020-01-22 14:28:06 +00:00

227 lines
5.7 KiB
Diff

From 08d2341a176248a346efbdaa6d8878f3ebd627da Mon Sep 17 00:00:00 2001
From: Jaroslav Kysela <perex@perex.cz>
Date: Thu, 12 Dec 2019 19:00:42 +0100
Subject: [PATCH 13/26] alsatplg: add -n,--normalize option
This function loads and parses the topology file and
saves back the structured output in the alsa-lib's format
without comments.
Signed-off-by: Jaroslav Kysela <perex@perex.cz>
---
topology/topology.c | 165 +++++++++++++++++++++++++++++++++++++++++++++-------
1 file changed, 145 insertions(+), 20 deletions(-)
diff --git a/topology/topology.c b/topology/topology.c
index b72e341fb5fd..a6ebafab161b 100644
--- a/topology/topology.c
+++ b/topology/topology.c
@@ -43,23 +43,154 @@ _("Usage: %s [OPTIONS]...\n"
"\n"
"-h, --help help\n"
"-c, --compile=FILE compile file\n"
+"-n, --normalize=FILE normalize file\n"
"-v, --verbose=LEVEL set verbosity level (0...1)\n"
"-o, --output=FILE set output file\n"
), name);
}
-int main(int argc, char *argv[])
+static int _compar(const void *a, const void *b)
+{
+ const snd_config_t *c1 = *(snd_config_t **)a;
+ const snd_config_t *c2 = *(snd_config_t **)b;
+ const char *id1, *id2;
+ if (snd_config_get_id(c1, &id1)) return 0;
+ if (snd_config_get_id(c2, &id2)) return 0;
+ return strcmp(id1, id2);
+}
+
+static snd_config_t *normalize_config(const char *id, snd_config_t *src)
+{
+ snd_config_t *dst, **a;
+ snd_config_iterator_t i, next;
+ int index, count;
+
+ if (snd_config_get_type(src) != SND_CONFIG_TYPE_COMPOUND) {
+ if (snd_config_copy(&dst, src) >= 0)
+ return dst;
+ return NULL;
+ }
+ if (snd_config_make_compound(&dst, id, 0))
+ return NULL;
+ count = 0;
+ snd_config_for_each(i, next, src)
+ count++;
+ a = malloc(sizeof(dst) * count);
+ if (a == NULL)
+ return NULL;
+ index = 0;
+ snd_config_for_each(i, next, src) {
+ snd_config_t *s = snd_config_iterator_entry(i);
+ a[index++] = s;
+ }
+ qsort(a, count, sizeof(a[0]), _compar);
+ for (index = 0; index < count; index++) {
+ snd_config_t *s = a[index];
+ const char *id2;
+ if (snd_config_get_id(s, &id2)) {
+ snd_config_delete(dst);
+ return NULL;
+ }
+ s = normalize_config(id2, s);
+ if (s == NULL || snd_config_add(dst, s)) {
+ snd_config_delete(dst);
+ return NULL;
+ }
+ }
+ return dst;
+}
+
+static int compile(const char *source_file, const char *output_file, int verbose)
{
snd_tplg_t *snd_tplg;
- static const char short_options[] = "hc:v:o:";
+ int err;
+
+ snd_tplg = snd_tplg_new();
+ if (snd_tplg == NULL) {
+ fprintf(stderr, _("failed to create new topology context\n"));
+ return 1;
+ }
+
+ snd_tplg_verbose(snd_tplg, verbose);
+
+ err = snd_tplg_build_file(snd_tplg, source_file, output_file);
+ if (err < 0) {
+ fprintf(stderr, _("failed to compile context %s\n"), source_file);
+ snd_tplg_free(snd_tplg);
+ unlink(output_file);
+ return 1;
+ }
+
+ snd_tplg_free(snd_tplg);
+ return 1;
+}
+
+static int normalize(const char *source_file, const char *output_file)
+{
+ snd_input_t *input;
+ snd_output_t *output;
+ snd_config_t *top, *norm;
+ int err;
+
+ err = snd_input_stdio_open(&input, source_file, "r");
+ if (err < 0) {
+ fprintf(stderr, "Unable to open source file '%s': %s\n", source_file, snd_strerror(-err));
+ return 0;
+ }
+
+ err = snd_config_top(&top);
+ if (err < 0) {
+ snd_input_close(input);
+ return 1;
+ }
+
+ err = snd_config_load(top, input);
+ snd_input_close(input);
+ if (err < 0) {
+ snd_config_delete(top);
+ fprintf(stderr, "Unable to parse source file '%s': %s\n", source_file, snd_strerror(-err));
+ snd_config_delete(top);
+ return 1;
+ }
+
+ err = snd_output_stdio_open(&output, output_file, "w+");
+ if (err < 0) {
+ fprintf(stderr, "Unable to open output file '%s': %s\n", output_file, snd_strerror(-err));
+ snd_config_delete(top);
+ return 1;
+ }
+
+ norm = normalize_config(NULL, top);
+ if (norm == NULL) {
+ fprintf(stderr, "Unable to normalize configuration (out of memory?)\n");
+ snd_output_close(output);
+ snd_config_delete(top);
+ return 1;
+ }
+
+ err = snd_config_save(norm, output);
+ snd_output_close(output);
+ snd_config_delete(top);
+ if (err < 0) {
+ fprintf(stderr, "Unable to save normalized contents: %s\n", snd_strerror(-err));
+ return 1;
+ }
+
+ return 0;
+}
+
+int main(int argc, char *argv[])
+{
+ static const char short_options[] = "hc:n:v:o:";
static const struct option long_options[] = {
{"help", 0, NULL, 'h'},
{"verbose", 1, NULL, 'v'},
{"compile", 1, NULL, 'c'},
+ {"normalize", 1, NULL, 'n'},
{"output", 1, NULL, 'o'},
{0, 0, 0, 0},
};
- char *source_file = NULL, *output_file = NULL;
+ char *source_file = NULL, *normalize_file = NULL, *output_file = NULL;
int c, err, verbose = 0, option_index;
#ifdef ENABLE_NLS
@@ -81,6 +212,9 @@ int main(int argc, char *argv[])
case 'c':
source_file = optarg;
break;
+ case 'n':
+ normalize_file = optarg;
+ break;
case 'o':
output_file = optarg;
break;
@@ -90,28 +224,19 @@ int main(int argc, char *argv[])
}
}
- if (source_file == NULL || output_file == NULL) {
- usage(argv[0]);
- return 1;
- }
-
- snd_tplg = snd_tplg_new();
- if (snd_tplg == NULL) {
- fprintf(stderr, _("failed to create new topology context\n"));
+ if (source_file && normalize_file) {
+ fprintf(stderr, "Cannot normalize and compile at a time!\n");
return 1;
}
- snd_tplg_verbose(snd_tplg, verbose);
-
- err = snd_tplg_build_file(snd_tplg, source_file, output_file);
- if (err < 0) {
- fprintf(stderr, _("failed to compile context %s\n"), source_file);
- snd_tplg_free(snd_tplg);
- unlink(output_file);
+ if ((source_file == NULL && normalize_file == NULL) || output_file == NULL) {
+ usage(argv[0]);
return 1;
}
- snd_tplg_free(snd_tplg);
+ if (source_file)
+ err = compile(source_file, output_file, verbose);
+ else
+ err = normalize(normalize_file, output_file);
return 0;
}
-
--
2.16.4