alsatplg: add -s,--sort and fix memory leaks

Signed-off-by: Jaroslav Kysela <perex@perex.cz>
This commit is contained in:
Jaroslav Kysela 2019-12-12 19:18:28 +01:00
parent 08d2341a17
commit 2656d4bec8

View file

@ -46,6 +46,7 @@ _("Usage: %s [OPTIONS]...\n"
"-n, --normalize=FILE normalize file\n" "-n, --normalize=FILE normalize file\n"
"-v, --verbose=LEVEL set verbosity level (0...1)\n" "-v, --verbose=LEVEL set verbosity level (0...1)\n"
"-o, --output=FILE set output file\n" "-o, --output=FILE set output file\n"
"-s, --sort sort the identifiers in the normalized output\n"
), name); ), name);
} }
@ -59,7 +60,7 @@ static int _compar(const void *a, const void *b)
return strcmp(id1, id2); return strcmp(id1, id2);
} }
static snd_config_t *normalize_config(const char *id, snd_config_t *src) static snd_config_t *normalize_config(const char *id, snd_config_t *src, int sort)
{ {
snd_config_t *dst, **a; snd_config_t *dst, **a;
snd_config_iterator_t i, next; snd_config_iterator_t i, next;
@ -70,8 +71,6 @@ static snd_config_t *normalize_config(const char *id, snd_config_t *src)
return dst; return dst;
return NULL; return NULL;
} }
if (snd_config_make_compound(&dst, id, 0))
return NULL;
count = 0; count = 0;
snd_config_for_each(i, next, src) snd_config_for_each(i, next, src)
count++; count++;
@ -83,20 +82,28 @@ static snd_config_t *normalize_config(const char *id, snd_config_t *src)
snd_config_t *s = snd_config_iterator_entry(i); snd_config_t *s = snd_config_iterator_entry(i);
a[index++] = s; a[index++] = s;
} }
if (sort)
qsort(a, count, sizeof(a[0]), _compar); qsort(a, count, sizeof(a[0]), _compar);
if (snd_config_make_compound(&dst, id, count == 1)) {
free(a);
return NULL;
}
for (index = 0; index < count; index++) { for (index = 0; index < count; index++) {
snd_config_t *s = a[index]; snd_config_t *s = a[index];
const char *id2; const char *id2;
if (snd_config_get_id(s, &id2)) { if (snd_config_get_id(s, &id2)) {
snd_config_delete(dst); snd_config_delete(dst);
free(a);
return NULL; return NULL;
} }
s = normalize_config(id2, s); s = normalize_config(id2, s, sort);
if (s == NULL || snd_config_add(dst, s)) { if (s == NULL || snd_config_add(dst, s)) {
snd_config_delete(dst); snd_config_delete(dst);
free(a);
return NULL; return NULL;
} }
} }
free(a);
return dst; return dst;
} }
@ -125,7 +132,7 @@ static int compile(const char *source_file, const char *output_file, int verbose
return 1; return 1;
} }
static int normalize(const char *source_file, const char *output_file) static int normalize(const char *source_file, const char *output_file, int sort)
{ {
snd_input_t *input; snd_input_t *input;
snd_output_t *output; snd_output_t *output;
@ -160,7 +167,7 @@ static int normalize(const char *source_file, const char *output_file)
return 1; return 1;
} }
norm = normalize_config(NULL, top); norm = normalize_config(NULL, top, sort);
if (norm == NULL) { if (norm == NULL) {
fprintf(stderr, "Unable to normalize configuration (out of memory?)\n"); fprintf(stderr, "Unable to normalize configuration (out of memory?)\n");
snd_output_close(output); snd_output_close(output);
@ -170,6 +177,7 @@ static int normalize(const char *source_file, const char *output_file)
err = snd_config_save(norm, output); err = snd_config_save(norm, output);
snd_output_close(output); snd_output_close(output);
snd_config_delete(norm);
snd_config_delete(top); snd_config_delete(top);
if (err < 0) { if (err < 0) {
fprintf(stderr, "Unable to save normalized contents: %s\n", snd_strerror(-err)); fprintf(stderr, "Unable to save normalized contents: %s\n", snd_strerror(-err));
@ -181,17 +189,18 @@ static int normalize(const char *source_file, const char *output_file)
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
static const char short_options[] = "hc:n:v:o:"; static const char short_options[] = "hc:n:v:o:s";
static const struct option long_options[] = { static const struct option long_options[] = {
{"help", 0, NULL, 'h'}, {"help", 0, NULL, 'h'},
{"verbose", 1, NULL, 'v'}, {"verbose", 1, NULL, 'v'},
{"compile", 1, NULL, 'c'}, {"compile", 1, NULL, 'c'},
{"normalize", 1, NULL, 'n'}, {"normalize", 1, NULL, 'n'},
{"output", 1, NULL, 'o'}, {"output", 1, NULL, 'o'},
{"sort", 0, NULL, 's'},
{0, 0, 0, 0}, {0, 0, 0, 0},
}; };
char *source_file = NULL, *normalize_file = NULL, *output_file = NULL; char *source_file = NULL, *normalize_file = NULL, *output_file = NULL;
int c, err, verbose = 0, option_index; int c, err, verbose = 0, sort = 0, option_index;
#ifdef ENABLE_NLS #ifdef ENABLE_NLS
setlocale(LC_ALL, ""); setlocale(LC_ALL, "");
@ -218,6 +227,9 @@ int main(int argc, char *argv[])
case 'o': case 'o':
output_file = optarg; output_file = optarg;
break; break;
case 's':
sort = 1;
break;
default: default:
fprintf(stderr, _("Try `%s --help' for more information.\n"), argv[0]); fprintf(stderr, _("Try `%s --help' for more information.\n"), argv[0]);
return 1; return 1;
@ -237,6 +249,8 @@ int main(int argc, char *argv[])
if (source_file) if (source_file)
err = compile(source_file, output_file, verbose); err = compile(source_file, output_file, verbose);
else else
err = normalize(normalize_file, output_file); err = normalize(normalize_file, output_file, sort);
snd_output_close(log);
return 0; return 0;
} }