/* SCOPE-LOCATOR.hpp - management and registration point for the QueryFocus-system Copyright (C) Lumiera.org 2009, 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. */ #ifndef MOBJECT_SESSION_SCOPE_LOCATOR_H #define MOBJECT_SESSION_SCOPE_LOCATOR_H #include "proc/mobject/session/scope.hpp" #include "proc/mobject/session/scope-query.hpp" #include "proc/mobject/placement.hpp" #include "lib/singleton.hpp" #include namespace mobject { namespace session { using boost::scoped_ptr; class QueryFocusStack; class ScopePath; /** * Singleton service establishing a link to relate * any compound of nested placement scopes to the current session * and the \em current focus for querying and exploring this structure. * While it is OK to use this service directly, clients usually would * prefer to use QueryFocus as a frontend. * * ScopeLocator is the access point both to the current query scope location * (as maintained with the help of the QueryFocusStack) and allows to explore * the current session data structures (building on a QueryResolver service * exposed by the session). * * @note in its current form (11/09), ScopeLocator is deliberately not threadsafe */ class ScopeLocator { scoped_ptr focusStack_; public: static lib::Singleton instance; ScopePath& currPath(); ScopePath& pushPath(); template typename ScopeQuery::iterator explore (Scope); template typename ScopeQuery::iterator query (Scope); template typename ScopeQuery::iterator locate (Scope scope); ~ScopeLocator(); protected: ScopeLocator(); friend class lib::singleton::StaticCreate; private: QueryResolver const& theResolver(); }; /** use the contents-resolving facility exposed by the session * to enumerate the contents (children) of the given scope */ template inline typename ScopeQuery::iterator ScopeLocator::explore (Scope scope) { return ScopeQuery (theResolver(), scope.getTop(), CHILDREN); } /** use the contents-resolving facility exposed by the session * to discover depth-first any object within this scope */ template inline typename ScopeQuery::iterator ScopeLocator::query (Scope scope) { return ScopeQuery (theResolver(), scope.getTop(), CONTENTS); } /** use the contents-resolving facility exposed by the session * to discover the path up from the given scope to model root */ template inline typename ScopeQuery::iterator ScopeLocator::locate (Scope scope) { return ScopeQuery (theResolver(), scope.getTop(), PATH); } }} // namespace mobject::session #endif