mirror of
https://github.com/alsa-project/alsa-utils
synced 2025-01-05 16:16:42 +01:00
alsatplg: add -s,--sort and fix memory leaks
Signed-off-by: Jaroslav Kysela <perex@perex.cz>
This commit is contained in:
parent
08d2341a17
commit
2656d4bec8
1 changed files with 24 additions and 10 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue