1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2008 Sun Microsystems, Inc.
4
* Copyright (C) 2008 Sun Microsystems
6
6
* This program is free software; you can redistribute it and/or modify
7
7
* it under the terms of the GNU General Public License as published by
17
17
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
#ifndef DRIZZLED_MODULE_REGISTRY_H
21
#define DRIZZLED_MODULE_REGISTRY_H
25
26
#include <algorithm>
28
#include <boost/algorithm/string.hpp>
29
#include <boost/scoped_ptr.hpp>
31
#include <drizzled/gettext.h>
32
#include <drizzled/unireg.h>
33
#include <drizzled/errmsg_print.h>
34
#include <drizzled/plugin/plugin.h>
35
#include <drizzled/util/find_ptr.h>
40
class Registry : boost::noncopyable
43
typedef std::map<std::string, Library*> LibraryMap;
44
typedef std::map<std::string, Module*> ModuleMap;
45
typedef std::vector<Module*> ModuleList;
28
#include "drizzled/gettext.h"
29
#include "drizzled/unireg.h"
30
#include "drizzled/errmsg_print.h"
47
LibraryMap library_registry_;
48
ModuleMap module_registry_;
49
boost::scoped_ptr<Graph> depend_graph_;
51
plugin::Plugin::map plugin_registry;
47
std::map<std::string, Library *> library_map;
48
std::map<std::string, Module *> module_map;
49
std::map<std::string, plugin::Plugin *> plugin_registry;
56
Registry(const Registry&);
57
Registry& operator=(const Registry&);
61
61
static Registry& singleton()
63
static Registry* registry= new Registry();
63
static Registry *registry= new Registry();
67
67
static void shutdown();
69
Module* find(const std::string&);
76
const plugin::Plugin::map &getPluginsMap() const
69
Module *find(std::string name);
71
void add(Module *module);
74
std::vector<Module *> getList(bool active);
76
const std::map<std::string, plugin::Plugin *> &getPluginsMap() const
78
78
return plugin_registry;
81
const ModuleMap &getModulesMap() const
81
const std::map<std::string, Module *> &getModulesMap() const
83
return module_registry_;
86
86
Library *addLibrary(const std::string &plugin_name, bool builtin= false);
93
93
void add(T *plugin)
95
95
bool failed= false;
96
std::string plugin_type(boost::to_lower_copy(plugin->getTypeName()));
97
std::string plugin_name(boost::to_lower_copy(plugin->getName()));
98
if (find_ptr(plugin_registry, std::make_pair(plugin_type, plugin_name)))
96
std::string plugin_name(plugin->getName());
97
std::transform(plugin_name.begin(), plugin_name.end(),
98
plugin_name.begin(), ::tolower);
99
if (plugin_registry.find(plugin_name) != plugin_registry.end())
100
errmsg_printf(error::ERROR, _("Loading plugin %s failed: a %s plugin by that name already exists.\n"),
101
plugin->getTypeName().c_str(), plugin->getName().c_str());
101
errmsg_printf(ERRMSG_LVL_ERROR,
102
_("Loading plugin %s failed: a plugin by that name already "
103
"exists.\n"), plugin->getName().c_str());
104
if (T::addPlugin(plugin)) // Olaf: Should addPlugin be called when failed is already true?
106
if (T::addPlugin(plugin))
109
errmsg_printf(error::ERROR, _("Fatal error: Failed initializing %s::%s plugin.\n"),
110
plugin->getTypeName().c_str(), plugin->getName().c_str());
110
errmsg_printf(ERRMSG_LVL_ERROR,
111
_("Fatal error: Failed initializing %s plugin.\n"),
112
plugin->getName().c_str());
113
plugin_registry.insert(std::make_pair(std::make_pair(plugin_type, plugin_name), plugin));
115
plugin_registry.insert(std::pair<std::string, plugin::Plugin *>(plugin_name, plugin));
116
118
template<class T>
117
119
void remove(T *plugin)
119
std::string plugin_type(boost::to_lower_copy(plugin->getTypeName()));
120
std::string plugin_name(boost::to_lower_copy(plugin->getName()));
121
std::string plugin_name(plugin->getName());
122
std::transform(plugin_name.begin(), plugin_name.end(),
123
plugin_name.begin(), ::tolower);
121
124
T::removePlugin(plugin);
122
plugin_registry.erase(std::make_pair(plugin_type, plugin_name));
125
plugin_registry.erase(plugin_name);