26
26
#include "drizzled/module/registry.h"
27
27
#include "drizzled/module/library.h"
28
#include "drizzled/module/graph.h"
29
#include "drizzled/module/vertex_handle.h"
31
29
#include "drizzled/plugin.h"
32
30
#include "drizzled/show.h"
33
31
#include "drizzled/cursor.h"
34
#include "drizzled/abort_exception.h"
36
33
#include <boost/bind.hpp>
43
module::Registry::Registry() :
45
depend_graph_(new module::Graph()),
51
41
module::Registry::~Registry()
53
plugin::Plugin::map::iterator plugin_iter;
43
std::map<std::string, plugin::Plugin *>::iterator plugin_iter;
55
45
/* Give all plugins a chance to cleanup, before
56
46
* all plugins are deleted.
67
plugin::Plugin::vector error_plugins;
68
57
plugin_iter= plugin_registry.begin();
69
58
while (plugin_iter != plugin_registry.end())
71
if ((*plugin_iter).second->removeLast())
73
error_plugins.push_back((*plugin_iter).second);
77
delete (*plugin_iter).second;
60
delete (*plugin_iter).second;
82
for (plugin::Plugin::vector::iterator iter= error_plugins.begin();
83
iter != error_plugins.end(); iter++)
88
63
plugin_registry.clear();
91
66
@TODO When we delete modules here, we segfault on a bad string. Why?
92
ModuleMap::iterator module_iter= module_registry_.begin();
67
map<string, module::Module *>::iterator module_iter= module_map.begin();
94
while (module_iter != module_registry_.end())
69
while (module_iter != module_map.end())
96
71
delete (*module_iter).second;
99
module_registry_.clear();
101
LibraryMap::iterator library_iter= library_registry_.begin();
102
while (library_iter != library_registry_.end())
76
std::map<std::string, module::Library *>::iterator library_iter= library_map.begin();
77
while (library_iter != library_map.end())
104
79
delete (*library_iter).second;
107
library_registry_.clear();
110
85
void module::Registry::shutdown()
118
93
std::transform(name.begin(), name.end(), name.begin(), ::tolower);
120
ModuleMap::iterator map_iter;
121
map_iter= module_registry_.find(name);
122
if (map_iter != module_registry_.end())
95
std::map<std::string, module::Module *>::iterator map_iter;
96
map_iter= module_map.find(name);
97
if (map_iter != module_map.end())
123
98
return (*map_iter).second;
127
102
void module::Registry::add(module::Module *handle)
130
105
transform(add_str.begin(), add_str.end(),
131
106
add_str.begin(), ::tolower);
133
module_registry_[add_str]= handle;
135
Vertex vertex_info(add_str, handle);
136
VertexDesc handle_vertex= boost::add_vertex(depend_graph_->getGraph());
137
depend_graph_->properties(handle_vertex)= vertex_info;
139
handle->setVertexHandle(new VertexHandle(handle_vertex));
108
module_map[add_str]= handle;
143
111
void module::Registry::remove(module::Module *handle)
146
114
std::transform(remove_str.begin(), remove_str.end(),
147
115
remove_str.begin(), ::tolower);
149
module_registry_.erase(remove_str);
117
module_map.erase(remove_str);
152
120
void module::Registry::copy(plugin::Plugin::vector &arg)
160
128
assert(arg.size() == plugin_registry.size());
163
void module::Registry::buildDeps()
165
ModuleMap::iterator map_iter= module_registry_.begin();
166
while (map_iter != module_registry_.end())
168
Module *handle= (*map_iter).second;
169
Module::Depends::const_iterator handle_deps= handle->getDepends().begin();
170
while (handle_deps != handle->getDepends().end())
172
std::string dep_str((*handle_deps));
173
transform(dep_str.begin(), dep_str.end(),
174
dep_str.begin(), ::tolower);
176
bool found_dep= false;
177
vertex_iter it= boost::vertices(depend_graph_->getGraph()).first;
178
while (it != vertices(depend_graph_->getGraph()).second)
180
if (depend_graph_->properties(*it).getName() == dep_str)
183
add_edge(handle->getVertexHandle()->getVertexDesc(), *it, depend_graph_->getGraph());
190
errmsg_printf(error::ERROR,
191
_("Couldn't process plugin module dependencies. "
192
"%s depends on %s but %s is not to be loaded.\n"),
193
handle->getName().c_str(),
194
dep_str.c_str(), dep_str.c_str());
205
module::Registry::ModuleList module::Registry::getList()
131
vector<module::Module *> module::Registry::getList(bool active)
133
module::Module *plugin= NULL;
212
135
std::vector<module::Module *> plugins;
214
VertexList vertex_list;
216
boost::topological_sort(depend_graph_->getGraph(), std::back_inserter(vertex_list));
218
for (VertexList::iterator i = vertex_list.begin();
219
i != vertex_list.end(); ++i)
136
plugins.reserve(module_map.size());
138
std::map<std::string, module::Module *>::iterator map_iter;
139
for (map_iter= module_map.begin();
140
map_iter != module_map.end();
221
Module *mod_ptr= depend_graph_->properties(*i).getModule();
224
plugins.push_back(mod_ptr);
143
plugin= (*map_iter).second;
145
plugins.push_back(plugin);
146
else if (plugin->isInited)
147
plugins.push_back(plugin);
252
174
void module::Registry::removeLibrary(const std::string &plugin_name)
254
176
std::map<std::string, module::Library *>::iterator iter=
255
library_registry_.find(plugin_name);
256
if (iter != library_registry_.end())
177
library_map.find(plugin_name);
178
if (iter != library_map.end())
258
library_registry_.erase(iter);
180
library_map.erase(iter);
259
181
delete (*iter).second;
263
185
module::Library *module::Registry::findLibrary(const std::string &plugin_name) const
265
LibraryMap::const_iterator iter= library_registry_.find(plugin_name);
266
if (iter != library_registry_.end())
187
std::map<std::string, module::Library *>::const_iterator iter=
188
library_map.find(plugin_name);
189
if (iter != library_map.end())
267
190
return (*iter).second;