AudioFormat.cxx 1.91 KB
Newer Older
1
/*
Max Kellermann's avatar
Max Kellermann committed
2
 * Copyright 2003-2021 The Music Player Daemon Project
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
 * http://www.musicpd.org
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 */

20
#include "AudioFormat.hxx"
21
#include "util/StringBuffer.hxx"
22

23 24
#include <cassert>

25
#include <stdio.h>
26

27
void
28
AudioFormat::ApplyMask(AudioFormat mask) noexcept
29
{
30 31
	assert(IsValid());
	assert(mask.IsMaskValid());
32

33 34
	if (mask.sample_rate != 0)
		sample_rate = mask.sample_rate;
35

36 37
	if (mask.format != SampleFormat::UNDEFINED)
		format = mask.format;
38

39 40
	if (mask.channels != 0)
		channels = mask.channels;
41

42
	assert(IsValid());
43 44
}

45
StringBuffer<24>
46
ToString(const AudioFormat af) noexcept
47
{
48 49 50
	StringBuffer<24> buffer;
	char *p = buffer.data();

51 52 53 54
	if (af.format == SampleFormat::DSD && af.sample_rate > 0 &&
	    af.sample_rate % 44100 == 0) {
		/* use shortcuts such as "dsd64" which implies the
		   sample rate */
55 56
		p += sprintf(p, "dsd%u:", af.sample_rate * 8 / 44100);
	} else {
57 58 59 60 61 62 63 64 65
		const char *sample_format = af.format != SampleFormat::UNDEFINED
			? sample_format_to_string(af.format)
			: "*";

		if (af.sample_rate > 0)
			p += sprintf(p, "%u:%s:", af.sample_rate,
				     sample_format);
		else
			p += sprintf(p, "*:%s:", sample_format);
66 67
	}

68 69 70 71 72 73
	if (af.channels > 0)
		p += sprintf(p, "%u", af.channels);
	else {
		*p++ = '*';
		*p = 0;
	}
74 75

	return buffer;
76
}