summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2017-04-12 20:26:16 +0200
committerDavid Robillard <d@drobilla.net>2017-04-12 20:26:16 +0200
commit0c6f4b52f6705185108909294432c3b03ff391c6 (patch)
tree71f946f9ace15f69bb6d41e2b73d5f836c9cdd67
parentc63c2359c943f6e7f061de22a7f513b0b925cec5 (diff)
downloadingen-0c6f4b52f6705185108909294432c3b03ff391c6.tar.gz
ingen-0c6f4b52f6705185108909294432c3b03ff391c6.tar.bz2
ingen-0c6f4b52f6705185108909294432c3b03ff391c6.zip
Manage world with a smart pointer
-rw-r--r--src/ingen/ingen.cpp15
1 files changed, 5 insertions, 10 deletions
diff --git a/src/ingen/ingen.cpp b/src/ingen/ingen.cpp
index 4eacfa97..5c0976f7 100644
--- a/src/ingen/ingen.cpp
+++ b/src/ingen/ingen.cpp
@@ -18,6 +18,7 @@
#include <stdlib.h>
#include <iostream>
+#include <memory>
#include <string>
#include <glibmm/thread.h>
@@ -43,14 +44,13 @@
using namespace std;
using namespace Ingen;
-Ingen::World* world = NULL;
+unique_ptr<Ingen::World> world;
static void
ingen_interrupt(int signal)
{
if (signal == SIGTERM) {
cerr << "ingen: Terminated" << endl;
- delete world;
exit(EXIT_FAILURE);
} else {
cout << "ingen: Interrupted" << endl;
@@ -65,7 +65,6 @@ ingen_try(bool cond, const char* msg)
{
if (!cond) {
cerr << "ingen: error: " << msg << endl;
- delete world;
exit(EXIT_FAILURE);
}
}
@@ -90,7 +89,7 @@ main(int argc, char** argv)
// Create world
try {
- world = new Ingen::World(NULL, NULL, NULL);
+ world = unique_ptr<Ingen::World>(new Ingen::World(NULL, NULL, NULL));
world->load_configuration(argc, argv);
if (argc <= 1) {
world->conf().print_usage("ingen", cout);
@@ -131,7 +130,7 @@ main(int argc, char** argv)
if (!engine_interface) {
ingen_try(world->load_module("client"), "Failed to load client module");
#ifdef HAVE_SOCKET
- Client::SocketClient::register_factories(world);
+ Client::SocketClient::register_factories(world.get());
#endif
const char* const uri = conf.option("connect").ptr<char>();
ingen_try(Raul::URI::is_valid(uri),
@@ -141,7 +140,6 @@ main(int argc, char** argv)
if (!engine_interface && !conf.option("gui").get<int32_t>()) {
cerr << (fmt("ingen: error: Failed to connect to `%1%'\n") % uri);
- delete world;
return EXIT_FAILURE;
}
}
@@ -157,14 +155,12 @@ main(int argc, char** argv)
if (world->engine()) {
if (!world->load_module("jack") && !world->load_module("portaudio")) {
cerr << "ingen: error: Failed to load driver module" << endl;
- delete world;
return EXIT_FAILURE;
}
if (!world->engine()->supports_dynamic_ports() &&
!conf.option("load").is_valid()) {
cerr << "ingen: error: Initial graph required for driver" << endl;
- delete world;
return EXIT_FAILURE;
}
}
@@ -196,7 +192,7 @@ main(int argc, char** argv)
std::lock_guard<std::mutex> lock(world->rdf_mutex());
world->parser()->parse_file(
- world, engine_interface.get(), graph, parent, symbol);
+ world.get(), engine_interface.get(), graph, parent, symbol);
} else if (conf.option("server-load").is_valid()) {
const char* path = conf.option("server-load").ptr<char>();
if (serd_uri_string_has_scheme((const uint8_t*)path)) {
@@ -261,7 +257,6 @@ main(int argc, char** argv)
std::cout << (fmt("Saved configuration to %1%") % path) << std::endl;
engine_interface.reset();
- delete world;
return 0;
}