summaryrefslogtreecommitdiffstats
path: root/src/server
diff options
context:
space:
mode:
Diffstat (limited to 'src/server')
-rw-r--r--src/server/Engine.cpp21
-rw-r--r--src/server/Engine.hpp40
-rw-r--r--src/server/SocketServer.hpp25
-rw-r--r--src/server/events/Delta.cpp22
-rw-r--r--src/server/events/Undo.cpp4
-rw-r--r--src/server/ingen_lv2.cpp4
6 files changed, 62 insertions, 54 deletions
diff --git a/src/server/Engine.cpp b/src/server/Engine.cpp
index 8fa4d2f5..7baea132 100644
--- a/src/server/Engine.cpp
+++ b/src/server/Engine.cpp
@@ -28,6 +28,8 @@
#include "ingen/Configuration.hpp"
#include "ingen/Log.hpp"
#include "ingen/Store.hpp"
+#include "ingen/StreamWriter.hpp"
+#include "ingen/Tee.hpp"
#include "ingen/URIs.hpp"
#include "ingen/World.hpp"
#include "ingen/types.hpp"
@@ -69,7 +71,8 @@ Engine::Engine(Ingen::World* world)
, _buffer_factory(new BufferFactory(*this, world->uris()))
, _control_bindings(NULL)
, _event_writer(new EventWriter(*this))
- , _atom_interface(new AtomReader(world->uri_map(), world->uris(), world->log(), *_event_writer))
+ , _interface(_event_writer)
+ , _atom_interface(nullptr)
, _maid(new Raul::Maid())
, _options(new LV2Options(world->uris()))
, _undo_stack(new UndoStack(_world->uris(), _world->uri_map()))
@@ -106,6 +109,21 @@ Engine::Engine(Ingen::World* world)
_world->lv2_features().add_feature(
SPtr<LV2Features::Feature>(
new LV2Features::EmptyFeature(LV2_STATE__loadDefaultState)));
+
+ if (world->conf().option("dump").get<int32_t>()) {
+ SPtr<Tee> tee(new Tee());
+ SPtr<StreamWriter> dumper(new StreamWriter(world->uri_map(),
+ world->uris(),
+ Raul::URI("ingen:/engine"),
+ stderr,
+ ColorContext::Color::MAGENTA));
+ tee->add_sink(_event_writer);
+ tee->add_sink(dumper);
+ _interface = tee;
+ }
+
+ _atom_interface = new AtomReader(
+ world->uri_map(), world->uris(), world->log(), *_interface.get());
}
Engine::~Engine()
@@ -144,7 +162,6 @@ Engine::~Engine()
delete _block_factory;
delete _control_bindings;
delete _broadcaster;
- delete _event_writer;
delete _worker;
delete _maid;
diff --git a/src/server/Engine.hpp b/src/server/Engine.hpp
index 82cbcdfb..32f284e0 100644
--- a/src/server/Engine.hpp
+++ b/src/server/Engine.hpp
@@ -28,6 +28,7 @@
#include "Event.hpp"
#include "RunContext.hpp"
+#include "EventWriter.hpp"
namespace Raul { class Maid; }
@@ -44,7 +45,6 @@ class Broadcaster;
class BufferFactory;
class ControlBindings;
class Driver;
-class EventWriter;
class GraphImpl;
class LV2Options;
class PostProcessor;
@@ -98,7 +98,8 @@ public:
Ingen::World* world() const { return _world; }
- EventWriter* interface() const { return _event_writer; }
+ Interface* interface() const { return _interface.get(); }
+ EventWriter* event_writer() const { return _event_writer.get(); }
AtomReader* atom_interface() const { return _atom_interface; }
BlockFactory* block_factory() const { return _block_factory; }
Broadcaster* broadcaster() const { return _broadcaster; }
@@ -123,23 +124,24 @@ public:
private:
Ingen::World* _world;
- BlockFactory* _block_factory;
- Broadcaster* _broadcaster;
- BufferFactory* _buffer_factory;
- ControlBindings* _control_bindings;
- SPtr<Driver> _driver;
- EventWriter* _event_writer;
- AtomReader* _atom_interface;
- Raul::Maid* _maid;
- SPtr<LV2Options> _options;
- UndoStack* _undo_stack;
- UndoStack* _redo_stack;
- PreProcessor* _pre_processor;
- PostProcessor* _post_processor;
- GraphImpl* _root_graph;
- Worker* _worker;
- Worker* _sync_worker;
- SocketListener* _listener;
+ BlockFactory* _block_factory;
+ Broadcaster* _broadcaster;
+ BufferFactory* _buffer_factory;
+ ControlBindings* _control_bindings;
+ SPtr<Driver> _driver;
+ SPtr<EventWriter> _event_writer;
+ SPtr<Interface> _interface;
+ AtomReader* _atom_interface;
+ Raul::Maid* _maid;
+ SPtr<LV2Options> _options;
+ UndoStack* _undo_stack;
+ UndoStack* _redo_stack;
+ PreProcessor* _pre_processor;
+ PostProcessor* _post_processor;
+ GraphImpl* _root_graph;
+ Worker* _worker;
+ Worker* _sync_worker;
+ SocketListener* _listener;
RunContext _run_context;
diff --git a/src/server/SocketServer.hpp b/src/server/SocketServer.hpp
index fc9fdeae..6420020e 100644
--- a/src/server/SocketServer.hpp
+++ b/src/server/SocketServer.hpp
@@ -17,10 +17,11 @@
#ifndef INGEN_SERVER_SOCKET_SERVER_HPP
#define INGEN_SERVER_SOCKET_SERVER_HPP
-#include "raul/Socket.hpp"
-
#include "ingen/SocketReader.hpp"
#include "ingen/SocketWriter.hpp"
+#include "ingen/StreamWriter.hpp"
+#include "ingen/Tee.hpp"
+#include "raul/Socket.hpp"
#include "EventWriter.hpp"
@@ -28,21 +29,29 @@ namespace Ingen {
namespace Server {
/** The server side of an Ingen socket connection. */
-class SocketServer : public EventWriter, public SocketReader
+class SocketServer
{
public:
SocketServer(World& world,
Server::Engine& engine,
SPtr<Raul::Socket> sock)
- : EventWriter(engine)
- , SocketReader(world, *this, sock)
- , _engine(engine)
+ : _engine(engine)
+ , _sink(world.conf().option("dump").get<int32_t>()
+ ? SPtr<Interface>(
+ new Tee({SPtr<Interface>(new EventWriter(engine)),
+ SPtr<Interface>(new StreamWriter(world.uri_map(),
+ world.uris(),
+ Raul::URI("ingen:/engine"),
+ stderr,
+ ColorContext::Color::CYAN))}))
+ : SPtr<Interface>(new EventWriter(engine)))
+ , _reader(new SocketReader(world, *_sink.get(), sock))
, _writer(new SocketWriter(world.uri_map(),
world.uris(),
sock->uri(),
sock))
{
- set_respondee(_writer);
+ _sink->set_respondee(_writer);
engine.register_client(_writer);
}
@@ -60,6 +69,8 @@ protected:
private:
Server::Engine& _engine;
+ SPtr<Interface> _sink;
+ SPtr<SocketReader> _reader;
SPtr<SocketWriter> _writer;
};
diff --git a/src/server/events/Delta.cpp b/src/server/events/Delta.cpp
index d54ec53f..49ea27ff 100644
--- a/src/server/events/Delta.cpp
+++ b/src/server/events/Delta.cpp
@@ -38,9 +38,6 @@
#include "SetPortValue.hpp"
#include "events/Get.hpp"
-// #define DUMP 1
-// #include "ingen/URIMap.hpp"
-
namespace Ingen {
namespace Server {
namespace Events {
@@ -74,25 +71,6 @@ Delta::Delta(Engine& engine,
p.second.set_context(context);
}
}
-
-#ifdef DUMP
- std::cerr << "Delta " << subject << " : " << (int)context << " {" << std::endl;
- typedef Resource::Properties::const_iterator iterator;
- for (iterator i = properties.begin(); i != properties.end(); ++i) {
- std::cerr << " + " << i->first
- << " " << engine.world()->forge().str(i->second)
- << "^^<" << engine.world()->uri_map().unmap_uri(i->second.type()) << ">"
- << std::endl;
- }
- typedef Resource::Properties::const_iterator iterator;
- for (iterator i = remove.begin(); i != remove.end(); ++i) {
- std::cerr << " - " << i->first
- << " " << engine.world()->forge().str(i->second)
- << "^^<" << engine.world()->uri_map().unmap_uri(i->second.type()) << ">"
- << std::endl;
- }
- std::cerr << "}" << std::endl;
-#endif
}
Delta::~Delta()
diff --git a/src/server/events/Undo.cpp b/src/server/events/Undo.cpp
index 06289aa1..15c18ca2 100644
--- a/src/server/events/Undo.cpp
+++ b/src/server/events/Undo.cpp
@@ -44,7 +44,7 @@ Undo::pre_process()
}
_entry = stack->pop();
- _engine.interface()->set_event_mode(mode);
+ _engine.event_writer()->set_event_mode(mode);
if (_entry.events.size() > 1) {
_engine.interface()->bundle_begin();
}
@@ -56,7 +56,7 @@ Undo::pre_process()
if (_entry.events.size() > 1) {
_engine.interface()->bundle_end();
}
- _engine.interface()->set_event_mode(mode);
+ _engine.event_writer()->set_event_mode(mode);
return Event::pre_process_done(Status::SUCCESS);
}
diff --git a/src/server/ingen_lv2.cpp b/src/server/ingen_lv2.cpp
index 53d302b1..0c32731c 100644
--- a/src/server/ingen_lv2.cpp
+++ b/src/server/ingen_lv2.cpp
@@ -544,8 +544,8 @@ ingen_instantiate(const LV2_Descriptor* descriptor,
plugin->engine = engine;
plugin->world->set_engine(engine);
- SPtr<EventWriter> interface = SPtr<EventWriter>(engine->interface(),
- NullDeleter<EventWriter>);
+ SPtr<Interface> interface = SPtr<Interface>(engine->interface(),
+ NullDeleter<Interface>);
plugin->world->set_interface(interface);