[alsa-devel] [RFCv2][PATCH 18/38] axfer: add informative output and an option to suppress it

Takashi Sakamoto o-takashi at sakamocchi.jp
Tue Sep 19 02:43:58 CEST 2017


In current aplay, some informative output is available as a default. This
can be suppressed by a quiet option. This commit adds support for it.

Unfortunately, original implementation includes contradiction in a case
to handle multiple files, thus this commit cannot keep fully compatibility.

Signed-off-by: Takashi Sakamoto <o-takashi at sakamocchi.jp>
---
 axfer/options.c         |  5 ++++-
 axfer/options.h         |  1 +
 axfer/subcmd-transfer.c | 27 +++++++++++++++++++++++++++
 3 files changed, 32 insertions(+), 1 deletion(-)

diff --git a/axfer/options.c b/axfer/options.c
index f3b0414b..a094ccb5 100644
--- a/axfer/options.c
+++ b/axfer/options.c
@@ -263,11 +263,12 @@ static int apply_policies(struct context_options *opts,
 int context_options_init(struct context_options *opts, int argc,
 			 char *const *argv, snd_pcm_stream_t direction)
 {
-	static const char *s_opts = "hvt:ID:f:c:r:";
+	static const char *s_opts = "hvqt:ID:f:c:r:";
 	static const struct option l_opts[] = {
 		/* For generic purposes. */
 		{"help",		0, 0, 'h'},
 		{"verbose",		0, 0, 'v'},
+		{"quiet",		0, 0, 'q'},
 		/* For containers. */
 		{"file-type",		1, 0, 't'},
 		/* For mapper. */
@@ -295,6 +296,8 @@ int context_options_init(struct context_options *opts, int argc,
 			opts->help = true;
 		else if (c == 'v')
 			++opts->verbose;
+		else if (c == 'q')
+			opts->quiet = true;
 		else if (c == 't')
 			cntr_format_literal = optarg;
 		else if (c == 'I')
diff --git a/axfer/options.h b/axfer/options.h
index 38bdbb74..9c9b46d7 100644
--- a/axfer/options.h
+++ b/axfer/options.h
@@ -16,6 +16,7 @@ struct context_options {
 
 	/* For generic purposes. */
 	unsigned int verbose;
+	bool quiet;
 
 	/* For containers. */
 	char **paths;
diff --git a/axfer/subcmd-transfer.c b/axfer/subcmd-transfer.c
index 9e39ff85..da11f43f 100644
--- a/axfer/subcmd-transfer.c
+++ b/axfer/subcmd-transfer.c
@@ -362,6 +362,21 @@ static int context_process_frames(struct context *ctx,
 	int i;
 	int err = 0;
 
+	if (!ctx->opts.quiet) {
+		fprintf(stderr,
+			_("%s: Format '%s', Rate %u Hz, Channels "),
+			snd_pcm_stream_name(direction),
+			snd_pcm_format_description(ctx->opts.sample_format),
+			ctx->opts.frames_per_second);
+		if (ctx->opts.samples_per_frame == 1)
+			fprintf(stderr, _("'monaural'"));
+		else if (ctx->opts.samples_per_frame == 2)
+			fprintf(stderr, "'Stereo'");
+		else
+			fprintf(stderr, "%u", ctx->opts.samples_per_frame);
+		fprintf(stderr, "\n");
+	}
+
 	*actual_frame_count = 0;
 	while (!ctx->interrupted) {
 		struct container_context *cntr;
@@ -388,6 +403,18 @@ static int context_process_frames(struct context *ctx,
 			break;
 	}
 
+	if (!ctx->opts.quiet) {
+		fprintf(stderr,
+			_("%s: Expected %lu frames, Actual %lu frames\n"),
+			snd_pcm_stream_name(direction), expected_frame_count,
+			*actual_frame_count);
+		if (ctx->interrupted) {
+			fprintf(stderr, _("Aborted by signal: %s\n"),
+			       strsignal(ctx->signal));
+			return 0;
+		}
+	}
+
 	return err;
 }
 
-- 
2.11.0



More information about the Alsa-devel mailing list