2 Copyright (C) 2000 Paul Davis
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 $Id: audio_source.h 486 2006-04-27 09:04:24Z pauld $
21 #ifndef __ardour_audio_source_h__
22 #define __ardour_audio_source_h__
30 #include <glibmm/thread.h>
32 #include <sigc++/signal.h>
34 #include <ardour/source.h>
35 #include <ardour/ardour.h>
36 #include <pbd/stateful.h>
37 #include <pbd/xml++.h>
45 const jack_nframes_t frames_per_peak = 256;
47 class AudioSource : public Source
50 AudioSource (string name);
51 AudioSource (const XMLNode&);
52 virtual ~AudioSource ();
54 virtual jack_nframes_t available_peaks (double zoom) const;
56 virtual jack_nframes_t read (Sample *dst, jack_nframes_t start, jack_nframes_t cnt) const;
57 virtual jack_nframes_t write (Sample *src, jack_nframes_t cnt);
59 virtual float sample_rate () const = 0;
61 virtual void mark_for_remove() = 0;
62 virtual void mark_streaming_write_completed () {}
64 void set_captured_for (string str) { _captured_for = str; }
65 string captured_for() const { return _captured_for; }
67 uint32_t read_data_count() const { return _read_data_count; }
68 uint32_t write_data_count() const { return _write_data_count; }
70 int read_peaks (PeakData *peaks, jack_nframes_t npeaks, jack_nframes_t start, jack_nframes_t cnt, double samples_per_unit) const;
72 bool peaks_ready (sigc::slot<void>, sigc::connection&) const;
74 static sigc::signal<void,AudioSource*> AudioSourceCreated;
76 mutable sigc::signal<void> PeaksReady;
77 mutable sigc::signal<void,jack_nframes_t,jack_nframes_t> PeakRangeReady;
79 XMLNode& get_state ();
80 int set_state (const XMLNode&);
82 static int start_peak_thread ();
83 static void stop_peak_thread ();
85 int rename_peakfile (std::string newpath);
87 static void set_build_missing_peakfiles (bool yn) {
88 _build_missing_peakfiles = yn;
91 static void set_build_peakfiles (bool yn) {
92 _build_peakfiles = yn;
96 static bool _build_missing_peakfiles;
97 static bool _build_peakfiles;
100 mutable Glib::Mutex _lock;
101 bool next_peak_clear_should_notify;
103 string _captured_for;
105 mutable uint32_t _read_data_count; // modified in read()
106 mutable uint32_t _write_data_count; // modified in write()
108 int initialize_peakfile (bool newfile, string path);
109 void build_peaks_from_scratch ();
111 int do_build_peak (jack_nframes_t, jack_nframes_t);
113 virtual jack_nframes_t read_unlocked (Sample *dst, jack_nframes_t start, jack_nframes_t cnt) const = 0;
114 virtual jack_nframes_t write_unlocked (Sample *dst, jack_nframes_t cnt) = 0;
115 virtual string peak_path(string audio_path) = 0;
116 virtual string old_peak_path(string audio_path) = 0;
118 static pthread_t peak_thread;
119 static bool have_peak_thread;
120 static void* peak_thread_work(void*);
122 static int peak_request_pipe[2];
131 static vector<AudioSource*> pending_peak_sources;
132 static Glib::Mutex* pending_peak_sources_lock;
134 static void queue_for_peaks (AudioSource&);
135 static void clear_queue_for_peaks ();
137 struct PeakBuildRecord {
138 jack_nframes_t frame;
141 PeakBuildRecord (jack_nframes_t f, jack_nframes_t c)
142 : frame (f), cnt (c) {}
143 PeakBuildRecord (const PeakBuildRecord& other) {
149 list<AudioSource::PeakBuildRecord *> pending_peak_builds;
152 bool file_changed (string path);
157 #endif /* __ardour_audio_source_h__ */