lumiera_/src/proc/asset.cpp
Ichthyostega 6bdf0e2cdc put my name in the copyright claim of those files I have written in the last months.
(search & replace). Please feel free to add your name to any files to which you added any contributions.
ALL SOURCECODE IS LICENCED UNDER THE TERMS AND CONDITIONS OF THE GPL (2 and above)
2007-11-27 03:19:35 +01:00

182 lines
4.5 KiB
C++

/*
Asset} - Superinterface: bookeeping view of "things" present in the session
Copyright (C) CinelerraCV
2007, Hermann Vosseler <Ichthyostega@web.de>
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/asset.hpp"
#include "proc/assetmanager.hpp"
#include "common/util.hpp"
#include <boost/function.hpp>
#include <boost/format.hpp>
#include <boost/bind.hpp>
using boost::bind;
using boost::format;
using boost::function;
using util::contains;
using util::removeall;
using util::for_each;
using util::and_all;
using util::cStr;
namespace asset
{
Asset::Ident::Ident(const string& n, const Category& cat, const string& o, const uint ver)
: name(util::sanitize (n)),
category(cat), org(o), version(ver)
{ }
/** Asset is a Interface class; usually, objects of
* concrete subclasses are created via specialized Factories
*/
Asset::Asset (const Ident& idi)
: ident(idi), id(AssetManager::reg (this, idi)), enabled(true)
{
TRACE (assetmem, "ctor Asset(id=%lu) : adr=%x %s", size_t(id), this, cStr(this->ident) );
}
Asset::~Asset ()
{
TRACE (assetmem, "dtor Asset(id=%lu) : adr=%x", size_t(id), this );
}
Asset::Ident::operator string () const
{
format id_tuple("(%2%:%3%.%1% v%4%)");
return str (id_tuple % name % category % org % version);
}
Asset::operator string () const
{
format id_tuple("Asset(%2%:%3%.%1% v%4%)");
return str (id_tuple % ident.name % ident.category % ident.org % ident.version);
}
function<bool(const PAsset&)> check_isActive
= bind ( &Asset::isActive
, bind (&PAsset::get, _1 )
);
bool
all_parents_enabled (const vector<PAsset>& parents)
{
return and_all (parents, check_isActive);
}
/**
* whether this asset is swithced on and consequently included
* in the fixture and participates in rendering.
*/
bool
Asset::isActive () const
{
return this->enabled
&& all_parents_enabled (parents);
}
void
propagate_down (PAsset child, bool on)
{
child->enable(on);
}
/**change the enablement status of this asset. */
bool
Asset::enable (bool on) throw(cinelerra::error::State)
{
if (on == this->enabled)
return true;
if (on && !all_parents_enabled (parents))
return false;
// can indeed to do the toggle...
this->enabled = on;
for_each (dependants, bind (&propagate_down, _1 ,on));
return true;
}
void
Asset::unregister (PAsset& other) ///< @internal
{
other->unlink (this->id);
}
/** release all links to other <i>dependant</i>
* asset objects held internally and advise all parent
* assets to do so with the link to this asset.
* @note we don't release upward links to parent assets,
* thus effectively keeping the parents alive, because
* frequently these accessible parent assets are part
* of our own contract. (e.g. media for clip assets)
*/
void
Asset::unlink ()
{
function<void(PAsset&)> forget_me = bind(&Asset::unregister, this,_1);
for_each (parents, forget_me);
dependants.clear();
}
/** variant dropping only the links to the given Asset */
void
Asset::unlink (IDA target)
{
PAsset asset (AssetManager::instance().getAsset (target));
removeall (dependants,asset);
removeall (parents,asset);
}
void
Asset::defineDependency (PAsset parent)
{
PAsset p_this (AssetManager::getPtr(*this));
REQUIRE (!contains (parent->dependants, p_this));
REQUIRE (!contains (this->parents, parent));
parents.push_back (parent);
parent->dependants.push_back(p_this);
}
void
Asset::defineDependency (Asset& parent)
{
PAsset p_parent (AssetManager::getPtr(parent));
ASSERT (p_parent);
defineDependency (p_parent);
}
} // namespace asset