- virtual nframes_t read_peaks (PeakData *buf, nframes_t npeaks,
- nframes_t offset, nframes_t cnt,
- uint32_t chan_n=0, double samples_per_unit= 1.0) const;
-
- virtual nframes_t read_at (Sample *buf, Sample *mixdown_buf,
- float *gain_buf, nframes_t position, nframes_t cnt,
- uint32_t chan_n = 0,
- nframes_t read_frames = 0,
- nframes_t skip_frames = 0) const;
-
- virtual nframes_t master_read_at (Sample *buf, Sample *mixdown_buf,
- float *gain_buf,
- nframes_t position, nframes_t cnt, uint32_t chan_n=0) const;
-
- XMLNode& state (bool);
- int set_state (const XMLNode&);
+ boost::shared_ptr<AutomationList> fade_in() { return _fade_in.val (); }
+ boost::shared_ptr<AutomationList> inverse_fade_in() { return _inverse_fade_in.val (); }
+ boost::shared_ptr<AutomationList> fade_out() { return _fade_out.val (); }
+ boost::shared_ptr<AutomationList> inverse_fade_out() { return _inverse_fade_out.val (); }
+ boost::shared_ptr<AutomationList> envelope() { return _envelope.val (); }
+
+ Evoral::Range<framepos_t> body_range () const;
+
+ virtual framecnt_t read_peaks (PeakData *buf, framecnt_t npeaks,
+ framecnt_t offset, framecnt_t cnt,
+ uint32_t chan_n=0, double samples_per_unit= 1.0) const;
+
+ /* Readable interface */
+
+ virtual framecnt_t read (Sample*, framepos_t pos, framecnt_t cnt, int channel) const;
+ virtual framecnt_t readable_length() const { return length(); }
+
+ virtual framecnt_t read_at (Sample *buf, Sample *mixdown_buf, float *gain_buf,
+ framepos_t position,
+ framecnt_t cnt,
+ uint32_t chan_n = 0) const;
+
+ virtual framecnt_t master_read_at (Sample *buf, Sample *mixdown_buf, float *gain_buf,
+ framepos_t position, framecnt_t cnt, uint32_t chan_n=0) const;
+
+ virtual framecnt_t read_raw_internal (Sample*, framepos_t, framecnt_t, int channel) const;
+
+ XMLNode& state ();
+ XMLNode& get_basic_state ();
+ int set_state (const XMLNode&, int version);