2007-09-02 18:48:22 +02:00
|
|
|
/*
|
|
|
|
|
Struct(Asset) - key abstraction: structural asset
|
|
|
|
|
|
|
|
|
|
Copyright (C) CinelerraCV
|
2007-11-27 03:19:35 +01:00
|
|
|
2007, Hermann Vosseler <Ichthyostega@web.de>
|
2007-09-02 18:48:22 +02:00
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
|
|
* *****************************************************/
|
|
|
|
|
|
|
|
|
|
|
2007-09-16 03:02:05 +02:00
|
|
|
#include "proc/assetmanager.hpp"
|
2007-09-02 18:48:22 +02:00
|
|
|
#include "proc/asset/struct.hpp"
|
2008-01-14 01:01:11 +01:00
|
|
|
#include "proc/asset/procpatt.hpp"
|
|
|
|
|
#include "proc/asset/track.hpp"
|
2008-01-27 23:40:45 +01:00
|
|
|
#include "proc/asset/port.hpp"
|
2008-01-14 01:01:11 +01:00
|
|
|
#include "proc/mobject/session.hpp"
|
2008-02-10 17:23:16 +01:00
|
|
|
#include "common/configrules.hpp"
|
|
|
|
|
|
|
|
|
|
#include "proc/asset/structfactoryimpl.hpp"
|
2008-01-07 18:16:03 +01:00
|
|
|
|
2007-09-16 03:02:05 +02:00
|
|
|
#include "common/util.hpp"
|
|
|
|
|
#include "nobugcfg.h"
|
2007-09-02 18:48:22 +02:00
|
|
|
|
2008-01-14 01:01:11 +01:00
|
|
|
using mobject::Session;
|
2008-01-18 16:43:53 +01:00
|
|
|
using cinelerra::query::normalizeID;
|
2008-01-14 01:01:11 +01:00
|
|
|
|
2008-02-10 17:23:16 +01:00
|
|
|
using cinelerra::ConfigRules;
|
|
|
|
|
using cinelerra::query::QueryHandler;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2007-09-02 18:48:22 +02:00
|
|
|
namespace asset
|
|
|
|
|
{
|
2007-09-16 03:02:05 +02:00
|
|
|
|
2008-02-10 17:23:16 +01:00
|
|
|
/****** NOTE: not really implemented yet. What follows is partially a hack to build simple tests *******/
|
2007-09-16 03:02:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-02-10 17:23:16 +01:00
|
|
|
/** storage for the static StructFactory instance */
|
|
|
|
|
StructFactory Struct::create;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** using private implementation detail class */
|
|
|
|
|
StructFactory::StructFactory ()
|
|
|
|
|
: impl_(new StructFactoryImpl(*this))
|
|
|
|
|
{ }
|
2007-09-16 03:02:05 +02:00
|
|
|
|
|
|
|
|
|
2008-02-10 17:23:16 +01:00
|
|
|
|
|
|
|
|
/** Factory method for Structural Asset instances.
|
|
|
|
|
* First tries to relove the asset by issuing an capability query.
|
|
|
|
|
* If unsuccessfull, use some internally specialized ctor call.
|
2008-01-07 18:16:03 +01:00
|
|
|
* @todo work out the struct asset naming scheme!
|
2007-09-16 03:02:05 +02:00
|
|
|
* @return an Struct smart ptr linked to the internally registered smart ptr
|
|
|
|
|
* created as a side effect of calling the concrete Struct subclass ctor.
|
|
|
|
|
*/
|
2008-02-10 17:23:16 +01:00
|
|
|
template<class STRU>
|
|
|
|
|
shared_ptr<STRU>
|
|
|
|
|
StructFactory::operator() (const Query<STRU>& capabilities)
|
2007-09-16 03:02:05 +02:00
|
|
|
{
|
2008-02-10 17:23:16 +01:00
|
|
|
QueryHandler<STRU>& typeHandler = ConfigRules::instance();
|
|
|
|
|
shared_ptr<STRU> res = typeHandler.resolve (capabilities);
|
|
|
|
|
|
|
|
|
|
if (res)
|
|
|
|
|
return res;
|
|
|
|
|
|
|
|
|
|
// create new one, since the
|
|
|
|
|
// ConfigQuery didn't yield any result
|
|
|
|
|
STRU* pS = impl_->fabricate(capabilities);
|
|
|
|
|
return AssetManager::instance().wrap (*pS);
|
2008-01-14 01:01:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2008-01-27 23:40:45 +01:00
|
|
|
|
|
|
|
|
|
2008-01-14 01:01:11 +01:00
|
|
|
/** 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<Port>
|
|
|
|
|
StructFactory::operator() (string portID, string streamID)
|
|
|
|
|
{
|
2008-01-18 16:43:53 +01:00
|
|
|
normalizeID (portID);
|
|
|
|
|
normalizeID (streamID);
|
2008-01-28 06:05:46 +01:00
|
|
|
PProcPatt processingPattern = Session::current->defaults (Query<const ProcPatt>("stream("+streamID+")"));
|
2008-01-14 01:01:11 +01:00
|
|
|
Port* pP = new Port (processingPattern, portID);
|
|
|
|
|
return AssetManager::instance().wrap (*pP);
|
2007-09-16 03:02:05 +02:00
|
|
|
}
|
2007-09-02 18:48:22 +02:00
|
|
|
|
|
|
|
|
|
2008-01-14 01:01:11 +01:00
|
|
|
|
2008-02-10 17:23:16 +01:00
|
|
|
} // namespace asset
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**************************************************/
|
|
|
|
|
/* explicit instantiations of the factory methods */
|
|
|
|
|
/**************************************************/
|
|
|
|
|
|
|
|
|
|
#include "proc/asset/struct.hpp"
|
|
|
|
|
#include "proc/asset/procpatt.hpp"
|
|
|
|
|
#include "proc/asset/track.hpp"
|
|
|
|
|
#include "proc/asset/port.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace asset
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
template shared_ptr<Port> StructFactory::operator() (const Query<Port>& query);
|
|
|
|
|
template shared_ptr<Track> StructFactory::operator() (const Query<Track>& query);
|
|
|
|
|
template PProcPatt StructFactory::operator() (const Query<const ProcPatt>& query);
|
|
|
|
|
|
|
|
|
|
|
2007-09-02 18:48:22 +02:00
|
|
|
} // namespace asset
|