/* Struct(Asset) - key abstraction: structural asset Copyright (C) CinelerraCV 2007, Hermann Vosseler 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 "proc/assetmanager.hpp" #include "proc/asset/struct.hpp" #include "proc/asset/procpatt.hpp" #include "proc/asset/track.hpp" #include "proc/mobject/session.hpp" #include "common/query.hpp" #include "common/util.hpp" #include "nobugcfg.h" using mobject::Session; using cinelerra::query::normalizeID; namespace asset { namespace // common Struct Asset implementation details { /** @internal derive a sensible asset ident tuple when creating * a track asset based on a query * @todo define the actual naming scheme of struct assets */ const Asset::Ident createTrackIdent (const Query& query) { string name ("track-" + query); // TODO something sensible here; append number, sanitize etc. TODO ("track naming scheme??"); Category category (STRUCT,"tracks"); return Asset::Ident (name, category ); } } StructFactory Struct::create; ///< storage for the static StructFactory instance /** Factory method for Structural Asset instances. .... * @todo work out the struct asset naming scheme! * @return an Struct smart ptr linked to the internally registered smart ptr * created as a side effect of calling the concrete Struct subclass ctor. */ template<> shared_ptr StructFactory::operator() (const Query& query) { TODO ("actually evaluate the query..."); Track* pT = new Track (createTrackIdent (query)); return AssetManager::instance().wrap (*pT); } /** Factory method for creating Ports explicitly. * Normalizes port- and streamID, then retrieves the * default processing pattern (ProcPatt) for this streamID. * The Port ctor will fill out the shortDesc and longDesc * automatically, based on portID and streamID (and they * are editable anyways) * @see ProcPatt * @see DefaultsManager */ shared_ptr StructFactory::operator() (string portID, string streamID) { normalizeID (portID); normalizeID (streamID); PProcPatt processingPattern = Session::current->defaults (Query("stream("+streamID+")")); Port* pP = new Port (processingPattern, portID); return AssetManager::instance().wrap (*pP); } } // namespace asset