lumiera_/src/proc/mobject/session/query-focus.hpp

155 lines
4.7 KiB
C++
Raw Normal View History

/*
QUERY-FOCUS.hpp - management of current scope within the Session
Copyright (C) Lumiera.org
2009, 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.
*/
#ifndef MOBJECT_SESSION_QUERY_FOCUS_H
#define MOBJECT_SESSION_QUERY_FOCUS_H
#include "proc/mobject/session/scope-path.hpp"
#include "proc/mobject/session/scope-locator.hpp"
#include <boost/intrusive_ptr.hpp>
namespace mobject {
namespace session {
/**
* Current focus location to use as point-of reference
* for contents and location discovery queries. This is the
* frontend to be used by client code: a smart-handle, internally
* linked through the ScopeLocaor singleton to a stack of current
* focus path locations. The intention is for this current location
* to follow the ongoing query/discovery operations mostly automatically.
*
* \par usage
*
* A QueryFocus (frontend handle) can be default constructed, in which
* case it will automatically connect to what is currently the focus
* location for any further queries. Here, the current focus location
* is defined as the most recently used location which is still referred
* by some QueryFocus handle.
*
* Alternatively, through the static factory function #push(), a new
* focus location may be opened, thereby pushing the currently used
* focus location aside. This new focus location will remain the
* current focus, while any handles referring to it is still in use.
*
* Using an existing QueryFocus (handle), the current focus may be
* shifted to another scope within the current session.
*
* The templated query functions allow to issue specifically typed
* queries to retrieve all children (immediately contained in a
* given scope), or do discover depth-first any content within
* this scope. The result set of these queries will be filtered
* to yield only placements compatible to the specified kind of
* MObject. E.g, you may query all Clip objects within a given Track.
*
* The implementation of these query operations is backed by the
* PlacementIndex in the current session. The link to the session
* is established the moment these query functions are invoked.
* The returned iterator (Lumiera Forward Iterator) contains a
* smart-ptr to keep the hidden result set alive. The results
* are delivered without any defined order (implementation is
* hashtable based)
*
* @see query-focus-test.cpp
*/
class QueryFocus
{
boost::intrusive_ptr<ScopePath> focus_;
public:
QueryFocus();
ScopePath currentPath() const;
operator Scope() const;
QueryFocus& attach (Scope const&);
static QueryFocus push (Scope const&);
QueryFocus& reset ();
QueryFocus& pop ();
template<class MO>
2009-11-20 19:58:22 +01:00
typename ScopeQuery<MO>::iterator
query() const;
2009-11-20 19:58:22 +01:00
template<class MO>
typename ScopeQuery<MO>::iterator
explore() const;
private:
QueryFocus (ScopePath&);
static ScopePath& currPath();
};
/** allowing direct conversion to Scope.
* Implemented by copying the scope at
* leaf position of the current focus path
*/
QueryFocus::operator Scope() const
{
return currPath().getLeaf();
}
/**@note returning a copy */
ScopePath
QueryFocus::currentPath() const
{
return currPath();
}
/** discover depth-first any matching object
* within \em current focus. Resolution is
* delegate to the \em current session */
template<class MO>
typename ScopeQuery<MO>::iterator
QueryFocus::query() const
{
ScopeLocator::instance().query<MO> (*this);
}
/** discover any matching object contained
* as immediate Child within \em current focus.
* Resolution through \em current session */
template<class MO>
typename ScopeQuery<MO>::iterator
QueryFocus::explore() const
{
ScopeLocator::instance().explore<MO> (*this);
}
}} // namespace mobject::session
#endif