enum { MAXCHAN = 4 }; enum { bi_basefreq = 0, bi_detune, bi_lowfreq, bi_hifreq, bi_lowvel, bi_hivel, bi_gain, bi_numparams }; typedef struct _buffer { t_object b_obj; // doesn't have any signals so it doesn't need to be pxobject long b_valid; // flag is off during read replacement or editing operation float *b_samples; // stored with interleaved channels if multi-channel long b_frames; // number of sample frames (each one is sizeof(float) * b_nchans bytes) long b_nchans; // number of channels long b_size; // size of buffer in floats float b_sr; // sampling rate of the buffer float b_1oversr; // 1 / sr float b_msr; // sr * .001 // Mac-specific stuff float *b_memory; // pointer to where memory starts (initial padding for interp) t_symbol *b_name; short b_vol; short b_space; // looping info (from AIFF file) long b_susloopstart; // in samples long b_susloopend; // in samples long b_relloopstart; // in samples long b_relloopend; // in samples // instrument info (from AIFF file) short b_inst[bi_numparams]; // window stuff void *b_wind; double b_pixperfr; double b_frperpix; long b_imagesize; Point b_scroll; long b_scrollscale; long b_selbegin[MAXCHAN]; long b_selend[MAXCHAN]; long b_zoom; long b_zim[11]; void *b_mouseout; long b_format; // 'AIFF' or 'Sd2f' t_symbol *b_filename; // last file read (not written) for readagain message long b_oldnchans; // used for resizing window in case of # of channels change void *b_doneout; long b_outputbytes; // number of bytes used for output sample (1-4) long b_modtime; // last modified time ("dirty" method) struct _buffer *b_peer; // objects that share this symbol (used as a link in the peers) Boolean b_owner; // b_memory/b_samples "owned" by this object long b_outputfmt; // sample type (A_LONG, A_FLOAT, etc.) } t_buffer; #define BUFWIND(x) ((t_wind *)(x->b_wind))