X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Faudiofilesource.cc;h=5a59ff339bc023c81a5e220d95df75d992190d43;hb=4e5423b3487771220cdca4c2b1a79c4d74b6afa5;hp=3bf252af3d3d36c6b6193e9f5e10058f7bf3febc;hpb=0b51d760ad4ca65c1bc9fa57a9d7f6a9ee6e5aab;p=ardour.git diff --git a/libs/ardour/audiofilesource.cc b/libs/ardour/audiofilesource.cc index 3bf252af3d..5a59ff339b 100644 --- a/libs/ardour/audiofilesource.cc +++ b/libs/ardour/audiofilesource.cc @@ -69,16 +69,16 @@ using namespace PBD; using namespace Glib; PBD::Signal0 AudioFileSource::HeaderPositionOffsetChanged; -framecnt_t AudioFileSource::header_position_offset = 0; +samplecnt_t AudioFileSource::header_position_offset = 0; /* XXX maybe this too */ char AudioFileSource::bwf_serial_number[13] = "000000000000"; struct SizedSampleBuffer { - framecnt_t size; + samplecnt_t size; Sample* buf; - SizedSampleBuffer (framecnt_t sz) : size (sz) { + SizedSampleBuffer (samplecnt_t sz) : size (sz) { buf = new Sample[size]; } @@ -208,10 +208,9 @@ XMLNode& AudioFileSource::get_state () { XMLNode& root (AudioSource::get_state()); - char buf[32]; - snprintf (buf, sizeof (buf), "%u", _channel); - root.add_property (X_("channel"), buf); - root.add_property (X_("origin"), _origin); + root.set_property (X_("channel"), _channel); + root.set_property (X_("origin"), _origin); + root.set_property (X_("gain"), _gain); return root; } @@ -250,7 +249,7 @@ AudioFileSource::move_dependents_to_trash() } void -AudioFileSource::set_header_position_offset (framecnt_t offset) +AudioFileSource::set_header_position_offset (samplecnt_t offset) { header_position_offset = offset; HeaderPositionOffsetChanged (); @@ -283,6 +282,20 @@ AudioFileSource::setup_peakfile () } } +void +AudioFileSource::set_gain (float g, bool temporarily) +{ + if (_gain == g) { + return; + } + _gain = g; + if (temporarily) { + return; + } + close_peakfile(); + setup_peakfile (); +} + bool AudioFileSource::safe_audio_file_extension(const string& file) { @@ -336,7 +349,7 @@ AudioFileSource::safe_audio_file_extension(const string& file) } Sample* -AudioFileSource::get_interleave_buffer (framecnt_t size) +AudioFileSource::get_interleave_buffer (samplecnt_t size) { SizedSampleBuffer* ssb;