/* This file is part of Ingen. Copyright 2007-2015 David Robillard Ingen is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. Ingen 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 Affero General Public License for details. You should have received a copy of the GNU Affero General Public License along with Ingen. If not, see . */ #ifndef INGEN_WORLD_HPP #define INGEN_WORLD_HPP #include "ingen/ingen.h" #include "ingen/types.hpp" #include "lv2/log/log.h" #include "lv2/urid/urid.h" #include "raul/Noncopyable.hpp" #include #include typedef struct LilvWorldImpl LilvWorld; namespace serd { class World; class Env; } namespace ingen { class Configuration; class EngineBase; class Forge; class Interface; class LV2Features; class Log; class Parser; class Serialiser; class Store; class URI; class URIMap; class URIs; /** The "world" all Ingen modules share. * * This is the root to which all components of Ingen are connected. It * contains all necessary shared data (including the world for libraries like * Serd and Lilv) and holds references to components. * * Some functionality in Ingen is implemented in dynamically loaded modules, * which are loaded using this interface. When loaded, those modules add * facilities to the World which can then be used throughout the code. * * The world is used in any process which uses the Ingen as a library, both * client and server (e.g. the world may not actually contain an Engine, since * it maybe running in another process or even on a different machine). * * @ingroup IngenShared */ class INGEN_API World : public Raul::Noncopyable { public: /** Construct a new Ingen world. * @param map LV2 URID map implementation, or null to use internal. * @param unmap LV2 URID unmap implementation, or null to use internal. * @param log LV2 log implementation, or null to use internal. */ World(LV2_URID_Map* map, LV2_URID_Unmap* unmap, LV2_Log_Log* log); virtual ~World(); /** Load configuration from files and command line. * @param argc Argument count (as in C main()) * @param argv Argument vector (as in C main()) */ virtual void load_configuration(int& argc, char**& argv); /** Load an Ingen module by name (e.g. "server", "gui", etc.) * @return True on success. */ virtual bool load_module(const char* name); /** Run a loaded module (modules that "run" only, e.g. gui). * @return True on success. */ virtual bool run_module(const char* name); /** A function to create a new remote Interface. */ typedef SPtr (*InterfaceFactory)(World& world, const URI& engine_uri, SPtr respondee); /** Register an InterfaceFactory (for module implementations). */ virtual void add_interface_factory(const std::string& scheme, InterfaceFactory factory); /** Return a new Interface to control a server. * @param engine_uri The URI of the possibly remote server to control. * @param respondee The Interface that will receive responses to commands * and broadcasts, if applicable. */ virtual SPtr new_interface(const URI& engine_uri, const SPtr& respondee); /** Run a script. */ virtual bool run(const std::string& mime_type, const std::string& filename); virtual void set_engine(const SPtr& e); virtual void set_interface(const SPtr& i); virtual void set_store(const SPtr& s); virtual SPtr engine(); virtual SPtr interface(); virtual SPtr parser(); virtual SPtr serialiser(); virtual SPtr store(); virtual int& argc(); virtual char**& argv(); virtual Configuration& conf(); /** Lock for rdf_world() or lilv_world(). */ virtual std::mutex& rdf_mutex(); virtual serd::World& rdf_world(); virtual serd::Env& env(); virtual LilvWorld* lilv_world(); virtual LV2Features& lv2_features(); virtual ingen::Forge& forge(); virtual URIMap& uri_map(); virtual URIs& uris(); virtual void set_jack_uuid(const std::string& uuid); virtual std::string jack_uuid(); virtual Log& log(); private: class Impl; Impl* _impl; }; } // namespace ingen #endif // INGEN_WORLD_HPP