2008-01-18 16:43:53 +01:00
|
|
|
/*
|
|
|
|
|
CONFIGRULES.hpp - interface for rule based configuration
|
|
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** @file configrules.hpp
|
|
|
|
|
** Interface for accessing rule based configuration.
|
|
|
|
|
** By using the Query template, you can pose a query in prolog syntax and get some
|
|
|
|
|
** existing or newly created object fulfilling the requested predicates. The actual
|
|
|
|
|
** implementation is hidden behind the #instance (Singleton factory). As of 1/2008,
|
|
|
|
|
** it is \i planned to use an embedded YAP Prolog system at some point in the future,
|
|
|
|
|
** for now we use a \link MockConfigRules mock implementation \endlink employing a
|
|
|
|
|
** preconfigured Map.
|
|
|
|
|
**
|
|
|
|
|
** Fully implementing this facility would require the participating objects to register capabilities
|
|
|
|
|
** they want to provide, together with functors carrying out the neccessary configuration steps.
|
|
|
|
|
** All details and consequences of this approach still have to be worked out...
|
|
|
|
|
**
|
2008-01-28 06:05:46 +01:00
|
|
|
** @note this is rather a scrapbook and in flux... don't take this code too literal!
|
|
|
|
|
**
|
2008-01-18 16:43:53 +01:00
|
|
|
** @see cinelerra::Query
|
|
|
|
|
** @see mobject::session::DefsManager
|
|
|
|
|
** @see asset::StructFactory
|
|
|
|
|
**
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef CINELERRA_CONFIGRULES_H
|
|
|
|
|
#define CINELERRA_CONFIGRULES_H
|
|
|
|
|
|
|
|
|
|
#include "common/query.hpp"
|
2008-01-21 02:57:09 +01:00
|
|
|
#include "common/typelist.hpp"
|
2008-02-01 15:35:33 +01:00
|
|
|
#include "common/singletonsubclass.hpp"
|
2008-01-21 02:57:09 +01:00
|
|
|
|
|
|
|
|
#include "proc/mobject/session/track.hpp"
|
2008-01-28 06:05:46 +01:00
|
|
|
#include "proc/asset/procpatt.hpp"
|
2008-01-21 02:57:09 +01:00
|
|
|
#include "proc/asset/port.hpp"
|
|
|
|
|
|
2008-01-18 16:43:53 +01:00
|
|
|
|
|
|
|
|
#include <string>
|
2008-01-28 06:05:46 +01:00
|
|
|
#include <tr1/memory>
|
2008-01-18 16:43:53 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace cinelerra
|
|
|
|
|
{
|
|
|
|
|
using std::string;
|
2008-01-28 06:05:46 +01:00
|
|
|
using std::tr1::shared_ptr;
|
|
|
|
|
|
2008-01-19 14:24:24 +01:00
|
|
|
|
2008-01-18 16:43:53 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace query
|
|
|
|
|
{
|
2008-01-19 14:24:24 +01:00
|
|
|
// The intention is to support the following style of Prolog code
|
|
|
|
|
//
|
2008-01-21 02:57:09 +01:00
|
|
|
// retrieve(O, Cap) :- find(T), capabilities(Cap).
|
|
|
|
|
// retrieve(O, Cap) :- make(T), capabilities(Cap).
|
|
|
|
|
// capabilities(Q) :- call(Q).
|
2008-01-19 14:24:24 +01:00
|
|
|
//
|
2008-01-21 02:57:09 +01:00
|
|
|
// stream(T, mpeg) :- type(T, track), type(P, port), retrieve(P, stream(P,mpeg)), place_to(P, T).
|
2008-01-19 14:24:24 +01:00
|
|
|
//
|
|
|
|
|
// The type guard is inserted auomatically, while the predicate implementations for
|
|
|
|
|
// find/1, make/1, stream/2, and place_to/2 are to be provided by the target types.
|
2008-01-21 02:57:09 +01:00
|
|
|
//
|
|
|
|
|
// As a example, the goal ":-retrieve(T, stream(T,mpeg))." would search a Track object, try to
|
|
|
|
|
// retrieve a port object with stream-type=mpeg and associate the track with this Port. The
|
|
|
|
|
// predicate "stream(P,mpeg)" needs to be implemented (natively) for the port object.
|
2008-01-19 14:24:24 +01:00
|
|
|
|
|
|
|
|
class Resolver
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
typedef const char * const Symbol;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< const Symbol SYM, // Predicate symbol
|
|
|
|
|
typename SIG = bool(string) // Signature
|
|
|
|
|
>
|
|
|
|
|
class Pred
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
template<class TY>
|
|
|
|
|
class TypeHandler
|
|
|
|
|
{
|
|
|
|
|
static const TY NIL;
|
|
|
|
|
|
|
|
|
|
template<Symbol SYM, typename SIG>
|
|
|
|
|
TY find (Pred<SYM,SIG> capability);
|
|
|
|
|
|
|
|
|
|
template<Symbol SYM, typename SIG>
|
|
|
|
|
TY make (Pred<SYM,SIG> capability, TY& refObj =NIL);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
template<class TY>
|
|
|
|
|
class QueryHandler
|
|
|
|
|
{
|
2008-01-21 02:57:09 +01:00
|
|
|
protected:
|
2008-01-29 05:39:32 +01:00
|
|
|
virtual ~QueryHandler() { }
|
2008-01-21 02:57:09 +01:00
|
|
|
public:
|
2008-01-29 05:39:32 +01:00
|
|
|
virtual shared_ptr<TY> resolve (Query<TY> q) = 0;
|
2008-01-21 02:57:09 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// TODO: the Idea is to provide specialisations for the concrete types
|
|
|
|
|
// we want to participate in the ConfigRules system....
|
|
|
|
|
// Thus we get the possibility to create a specific return type,
|
|
|
|
|
// e.g. return a shared_ptr<Port> but a Placement<Track>, using the appropriate factory.
|
|
|
|
|
// Of course then the definitions need to be split up in separate headers.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
using cinelerra::typelist::Node;
|
|
|
|
|
using cinelerra::typelist::NullType;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Generic query interface for retrieving objects matching
|
|
|
|
|
* some capability query. To be instantiated using a typelist,
|
|
|
|
|
* thus inheriting from the Handler classes for each type. In
|
|
|
|
|
* the (future) version using YAP Prolog, this will drive the
|
|
|
|
|
* generation and registration of the necessary predicate
|
|
|
|
|
* implementations for each concrete type, using the speicalisations
|
|
|
|
|
* given alongside with the types. For now it just serves to generate
|
|
|
|
|
* the necessary resolve(Query<TY>) virtual functions (implemented
|
|
|
|
|
* by MockConfigRules)
|
|
|
|
|
*/
|
|
|
|
|
template<class TYPES>
|
|
|
|
|
class ConfigRulesInterface;
|
|
|
|
|
|
|
|
|
|
template<>
|
|
|
|
|
class ConfigRulesInterface<NullType>
|
|
|
|
|
{
|
|
|
|
|
protected:
|
|
|
|
|
virtual ~ConfigRulesInterface();
|
2008-01-19 14:24:24 +01:00
|
|
|
};
|
2008-01-21 02:57:09 +01:00
|
|
|
|
|
|
|
|
template<class TY, typename TYPES>
|
|
|
|
|
class ConfigRulesInterface<Node<TY, TYPES> >
|
|
|
|
|
: public QueryHandler<TY>,
|
|
|
|
|
public ConfigRulesInterface<TYPES>
|
|
|
|
|
{ };
|
|
|
|
|
|
2008-01-18 16:43:53 +01:00
|
|
|
|
2008-02-01 15:35:33 +01:00
|
|
|
template<typename TYPES>
|
2008-01-21 02:57:09 +01:00
|
|
|
class ConfigRules
|
|
|
|
|
: public ConfigRulesInterface<typename TYPES::List>
|
|
|
|
|
{
|
|
|
|
|
protected:
|
|
|
|
|
ConfigRules () {}
|
|
|
|
|
virtual ~ConfigRules() {}
|
|
|
|
|
|
2008-02-01 15:35:33 +01:00
|
|
|
public:
|
2008-01-21 02:57:09 +01:00
|
|
|
// TODO: find out what operations we need to support here for the »real solution« (using Prolog)
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2008-01-18 16:43:53 +01:00
|
|
|
|
2008-01-28 06:05:46 +01:00
|
|
|
|
|
|
|
|
CINELERRA_ERROR_DECLARE (CAPABILITY_QUERY); ///< unresolvable capability query.
|
2008-01-18 16:43:53 +01:00
|
|
|
|
|
|
|
|
} // namespace query
|
2008-01-21 02:57:09 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* ============= global configuration ==================== */
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* the list of all concrete types participating in the
|
|
|
|
|
* rule based config query system
|
|
|
|
|
*/
|
|
|
|
|
typedef cinelerra::typelist::Types < mobject::session::Track
|
|
|
|
|
, asset::Port
|
2008-01-28 06:05:46 +01:00
|
|
|
, const asset::ProcPatt
|
2008-01-21 02:57:09 +01:00
|
|
|
>
|
|
|
|
|
InterfaceTypes;
|
|
|
|
|
|
2008-02-01 15:35:33 +01:00
|
|
|
/**
|
|
|
|
|
* user-visible Interface to the ConfigRules subsystem.
|
|
|
|
|
* Configured as Singleton (with hidden Implementation class)
|
|
|
|
|
*/
|
|
|
|
|
class ConfigRules
|
|
|
|
|
: public query::ConfigRules<InterfaceTypes>
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
static SingletonSub<ConfigRules> instance;
|
|
|
|
|
|
|
|
|
|
};
|
2008-01-21 02:57:09 +01:00
|
|
|
|
|
|
|
|
|
2008-01-18 16:43:53 +01:00
|
|
|
} // namespace cinelerra
|
|
|
|
|
#endif
|