LUMIERA.clone/src/proc/mobject/session/session-interface-modules.hpp

131 lines
4.8 KiB
C++
Raw Normal View History

/*
SESSION-INTERFACE-MODULES.hpp - holds the complete session data to be edited by the user
Copyright (C) Lumiera.org
2010, 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.
*/
/** @file session-interface-modules.hpp
** Self-contained sub-elements on the Session API.
** Part of the Session interface is exposed as self-contained
** interface modules -- both for notational convenience at the
** usage site, and for keeping session implementation code manageable.
** Clients access these modules as nested parts of the public Session interface
** through references exposing just the respective interfaces, while the actual
** implementation is located in-place (within the SesssionImpl object), packaged
** into a non-public baseclass.
** - the DefsManager acts as frontend to the system of default configurations
** and config rules, allowing to retrieve the \em default version of various
** kinds of objects
** - the top-level Timeline (structural assets) act as facade and entry point
** to the high-level-model (session contents). There is an table of timelines,
** managed automatically and kept in sync with the session::Binding elements
** located directly below model root.
** - likewise there is an table of all Sequence (structural assets), which
** correspond to the roots of track trees, attached below model root.
**
** \par maintaining the link between session, timelines and sequences
** Timeline and Sequence are implemented as asset::Struct, causing them to be
** maintained by the AssetManager, which in turn is attached to the session::Root
** (WIP 3/2010: yet to be implemented). Creation and destruction of timelines and
** sequences is closely connected to some structural changes within the model
** - Timeline is related to session::Binding, where the timelines are leading
** and the binding elements are dependent on both a timeline and a sequence
** - Sequence is related to a Placement<session::Track> -- but only if attached
** immediately below model root; here the tracks are leading and the sequences
** are completely dependent.
** In any case, ctor and dtor of Timeline and Sequence have to care for proper
** registration into the SessionInterfaceModules for timelines and sequences
** respectively. This is accomplished by using kind-of a backdoor, a SessionServices
** (proc internal API) definition, allowing direct communication on implementation
** level, without the need to expose this access point on the public session API.
** The impl::ElementTracker implemented in this sourcefile here relieves these
** calls to maintain a list of asset smart-ptrs
**
** @see SessionImpl
** @see session-services.hpp
**
*/
#ifndef MOBJECT_SESSION_INTERFACE_MODULES_H
#define MOBJECT_SESSION_INTERFACE_MODULES_H
#include "lib/p.hpp"
#include "lib/ref-array-impl.hpp"
namespace mobject {
namespace session {
namespace impl { // impl: list of elements to track
using lumiera::P;
/**
* Custom implementation of the RefArray interface,
* used by the Session to keep track of all timelines
* and sequences. The registration/deregistration functions
* are accessible as SessionServices
*/
template<typename ELM>
class ElementTracker
: public lib::RefArrayVectorWrapper<P<ELM> >
{
public:
void
add (P<ELM> const& asset)
{
UNIMPLEMENTED ("attach entry to session");
}
void
remove (P<ELM> const& asset)
{
UNIMPLEMENTED ("detach entry from session");
}
};
} //(End) impl list of elements to track
typedef impl::ElementTracker<asset::Timeline> TimelineTracker;
typedef impl::ElementTracker<asset::Sequence> SequenceTracker;
/**
* Collection of implementation components,
* providing self-contained sub-elements
* exposed on the public Session API.
*/
struct SessionInterfaceModules
: boost::noncopyable
{
DefsManager defaultsManager_;
TimelineTracker timelineRegistry_;
SequenceTracker sequenceRegistry_;
};
}} // namespace mobject::session
#endif