- /* this might throw failed_constructor(), which is OK */
-
- boost::shared_ptr<Source> ret (new SndFileSource
- (s, path,
- Config->get_native_file_data_format(),
- Config->get_native_file_header_format(),
- rate,
- (destructive ? SndFileSource::default_writable_flags :
- AudioFileSource::Flag
- (SndFileSource::default_writable_flags | AudioFileSource::Destructive))));
-
- if (setup_peakfile (ret)) {
- return boost::shared_ptr<Source>();
- }
- if (announce) {
- SourceCreated (ret);
+ if (type == DataType::AUDIO) {
+ try {
+
+ boost::shared_ptr<AudioPlaylist> ap = boost::dynamic_pointer_cast<AudioPlaylist>(p);
+
+ if (ap) {
+
+ if (copy) {
+ ap.reset (new AudioPlaylist (ap, start, len, name, true));
+ start = 0;
+ }
+
+ Source* src = new AudioPlaylistSource (s, orig, name, ap, chn, start, len, Source::Flag (0));
+ boost::shared_ptr<Source> ret (src);
+
+ if (setup_peakfile (ret, defer_peaks)) {
+ return boost::shared_ptr<Source>();
+ }
+
+ ret->check_for_analysis_data_on_disk ();
+ SourceCreated (ret);
+ return ret;
+ }
+ }
+
+ catch (failed_constructor& err) {
+ /* relax - return at function scope */
+ }
+
+ } else if (type == DataType::MIDI) {
+
+ try {
+
+ boost::shared_ptr<MidiPlaylist> ap = boost::dynamic_pointer_cast<MidiPlaylist>(p);
+
+ if (ap) {
+
+ if (copy) {
+ ap.reset (new MidiPlaylist (ap, start, len, name, true));
+ start = 0;
+ }
+
+ Source* src = new MidiPlaylistSource (s, orig, name, ap, chn, start, len, Source::Flag (0));
+ boost::shared_ptr<Source> ret (src);
+
+ SourceCreated (ret);
+ return ret;
+ }
+ }
+
+ catch (failed_constructor& err) {
+ /* relax - return at function scope */
+ }
+