Path: blob/a-new-beginning/Cherry/Core/include/audio/Multi_Buffer.h
2 views
// Multi-channel sound buffer interface, and basic mono and stereo buffers12// Blip_Buffer 0.4.13#ifndef MULTI_BUFFER_H4#define MULTI_BUFFER_H56#include "blargg_common.h"7#include "Blip_Buffer.h"89// Interface to one or more Blip_Buffers mapped to one or more channels10// consisting of left, center, and right buffers.11class Multi_Buffer {12public:13Multi_Buffer( int samples_per_frame );14virtual ~Multi_Buffer() { }1516// Sets the number of channels available and optionally their types17// (type information used by Effects_Buffer)18enum { type_index_mask = 0xFF };19enum { wave_type = 0x100, noise_type = 0x200, mixed_type = wave_type | noise_type };20virtual blargg_err_t set_channel_count( int, int const* types = 0 );21int channel_count() const { return channel_count_; }2223// Gets indexed channel, from 0 to channel count - 124struct channel_t {25Blip_Buffer* center;26Blip_Buffer* left;27Blip_Buffer* right;28};29virtual channel_t channel( int index ) BLARGG_PURE( ; )3031// See Blip_Buffer.h32virtual blargg_err_t set_sample_rate( long rate, int msec = blip_default_length ) BLARGG_PURE( ; )33virtual void clock_rate( long ) BLARGG_PURE( { } )34virtual void bass_freq( int ) BLARGG_PURE( { } )35virtual void clear() BLARGG_PURE( { } )36long sample_rate() const;3738// Length of buffer, in milliseconds39int length() const;4041// See Blip_Buffer.h42virtual void end_frame( blip_time_t ) BLARGG_PURE( { } )4344// Number of samples per output frame (1 = mono, 2 = stereo)45int samples_per_frame() const;4647// Count of changes to channel configuration. Incremented whenever48// a change is made to any of the Blip_Buffers for any channel.49unsigned channels_changed_count() { return channels_changed_count_; }5051// See Blip_Buffer.h52virtual long read_samples( blip_sample_t*, long ) BLARGG_PURE( { return 0; } )53virtual long samples_avail() const BLARGG_PURE( { return 0; } )5455public:56BLARGG_DISABLE_NOTHROW57void disable_immediate_removal() { immediate_removal_ = false; }58protected:59bool immediate_removal() const { return immediate_removal_; }60int const* channel_types() const { return channel_types_; }61void channels_changed() { channels_changed_count_++; }62private:63// noncopyable64Multi_Buffer( const Multi_Buffer& );65Multi_Buffer& operator = ( const Multi_Buffer& );6667unsigned channels_changed_count_;68long sample_rate_;69int length_;70int channel_count_;71int const samples_per_frame_;72int const* channel_types_;73bool immediate_removal_;74};7576// Uses a single buffer and outputs mono samples.77class Mono_Buffer : public Multi_Buffer {78Blip_Buffer buf;79channel_t chan;80public:81// Buffer used for all channels82Blip_Buffer* center() { return &buf; }8384public:85Mono_Buffer();86~Mono_Buffer();87blargg_err_t set_sample_rate( long rate, int msec = blip_default_length );88void clock_rate( long rate ) { buf.clock_rate( rate ); }89void bass_freq( int freq ) { buf.bass_freq( freq ); }90void clear() { buf.clear(); }91long samples_avail() const { return buf.samples_avail(); }92long read_samples( blip_sample_t* p, long s ) { return buf.read_samples( p, s ); }93channel_t channel( int ) { return chan; }94void end_frame( blip_time_t t ) { buf.end_frame( t ); }95};9697class Tracked_Blip_Buffer : public Blip_Buffer {98public:99// Non-zero if buffer still has non-silent samples in it. Requires that you call100// set_modified() appropriately.101blip_ulong non_silent() const;102103// remove_samples( samples_avail() )104void remove_all_samples();105106public:107BLARGG_DISABLE_NOTHROW108109long read_samples( blip_sample_t*, long );110void remove_silence( long );111void remove_samples( long );112Tracked_Blip_Buffer();113void clear();114void end_frame( blip_time_t );115private:116blip_long last_non_silence;117void remove_( long );118};119120class Stereo_Mixer {121public:122Tracked_Blip_Buffer* bufs [3];123blargg_long samples_read;124125Stereo_Mixer() : samples_read( 0 ) { }126void read_pairs( blip_sample_t* out, int count );127private:128void mix_mono ( blip_sample_t* out, int pair_count );129void mix_stereo( blip_sample_t* out, int pair_count );130};131132// Uses three buffers (one for center) and outputs stereo sample pairs.133class Stereo_Buffer : public Multi_Buffer {134public:135136// Buffers used for all channels137Blip_Buffer* center() { return &bufs [2]; }138Blip_Buffer* left() { return &bufs [0]; }139Blip_Buffer* right() { return &bufs [1]; }140141public:142Stereo_Buffer();143~Stereo_Buffer();144blargg_err_t set_sample_rate( long, int msec = blip_default_length );145void clock_rate( long );146void bass_freq( int );147void clear();148channel_t channel( int ) { return chan; }149void end_frame( blip_time_t );150151long samples_avail() const { return (bufs [0].samples_avail() - mixer.samples_read) * 2; }152long read_samples( blip_sample_t*, long );153154private:155enum { bufs_size = 3 };156typedef Tracked_Blip_Buffer buf_t;157buf_t bufs [bufs_size];158Stereo_Mixer mixer;159channel_t chan;160};161162// Silent_Buffer generates no samples, useful where no sound is wanted163class Silent_Buffer : public Multi_Buffer {164channel_t chan;165public:166Silent_Buffer();167blargg_err_t set_sample_rate( long rate, int msec = blip_default_length );168void clock_rate( long ) { }169void bass_freq( int ) { }170void clear() { }171channel_t channel( int ) { return chan; }172void end_frame( blip_time_t ) { }173long samples_avail() const { return 0; }174long read_samples( blip_sample_t*, long ) { return 0; }175};176177178inline blargg_err_t Multi_Buffer::set_sample_rate( long rate, int msec )179{180sample_rate_ = rate;181length_ = msec;182return 0;183}184185inline blargg_err_t Silent_Buffer::set_sample_rate( long rate, int msec )186{187return Multi_Buffer::set_sample_rate( rate, msec );188}189190inline int Multi_Buffer::samples_per_frame() const { return samples_per_frame_; }191192inline long Multi_Buffer::sample_rate() const { return sample_rate_; }193194inline int Multi_Buffer::length() const { return length_; }195196inline blargg_err_t Multi_Buffer::set_channel_count( int n, int const* types )197{198channel_count_ = n;199channel_types_ = types;200return 0;201}202203#endif204205206