From 449aab3c465bbbf66d221fac3d7ea559f1720357 Mon Sep 17 00:00:00 2001 From: Paul Davis Date: Mon, 2 Jun 2008 21:41:35 +0000 Subject: rollback to 3428, before the mysterious removal of libs/* at 3431/3432 git-svn-id: svn://localhost/ardour2/branches/3.0@3435 d708f5d6-7413-0410-9779-e7cbd77b26cf --- libs/ardour/filter.cc | 123 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 libs/ardour/filter.cc (limited to 'libs/ardour/filter.cc') diff --git a/libs/ardour/filter.cc b/libs/ardour/filter.cc new file mode 100644 index 0000000000..be382f72da --- /dev/null +++ b/libs/ardour/filter.cc @@ -0,0 +1,123 @@ +/* + Copyright (C) 2004-2007 Paul Davis + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +*/ + +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "i18n.h" + +using namespace ARDOUR; +using namespace PBD; + +int +Filter::make_new_sources (boost::shared_ptr region, SourceList& nsrcs, string suffix) +{ + vector names = region->master_source_names(); + + for (uint32_t i = 0; i < region->n_channels(); ++i) { + + string name = PBD::basename_nosuffix (names[i]); + + /* remove any existing version of suffix by assuming it starts + with some kind of "special" character. + */ + + if (!suffix.empty()) { + string::size_type pos = name.find (suffix[0]); + if (pos != string::npos && pos > 2) { + name = name.substr (0, pos - 1); + } + } + + string path = session.path_from_region_name (region->data_type(), + PBD::basename_nosuffix (names[i]), string ("")); + + if (path.length() == 0) { + error << string_compose (_("filter: error creating name for new file based on %1"), region->name()) + << endmsg; + return -1; + } + + try { + nsrcs.push_back (boost::dynamic_pointer_cast ( + SourceFactory::createWritable (region->data_type(), session, path, false, session.frame_rate()))); + } + + catch (failed_constructor& err) { + error << string_compose (_("filter: error creating new file %1 (%2)"), path, strerror (errno)) << endmsg; + return -1; + } + } + + return 0; +} + +int +Filter::finish (boost::shared_ptr region, SourceList& nsrcs, string region_name) +{ + /* update headers on new sources */ + + time_t xnow; + struct tm* now; + + time (&xnow); + now = localtime (&xnow); + + /* this is ugly. */ + for (SourceList::iterator si = nsrcs.begin(); si != nsrcs.end(); ++si) { + boost::shared_ptr afs = boost::dynamic_pointer_cast(*si); + if (afs) { + afs->update_header (region->position(), *now, xnow); + afs->mark_immutable (); + } + + boost::shared_ptr smfs = boost::dynamic_pointer_cast(*si); + if (smfs) { + smfs->set_timeline_position (region->position()); + smfs->flush_footer (); + } + + /* now that there is data there, requeue the file for analysis */ + + Analyser::queue_source_for_analysis (*si, false); + } + + /* create a new region */ + + if (region_name.empty()) { + region_name = session.new_region_name (region->name()); + } + results.clear (); + results.push_back (RegionFactory::create (nsrcs, 0, region->length(), region_name, 0, + Region::Flag (Region::WholeFile|Region::DefaultFlags))); + + return 0; +} + + -- cgit v1.2.3