~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/plugin_registry_impl.cc

  • Committer: Brian Aker
  • Date: 2009-03-03 18:50:34 UTC
  • mfrom: (908.1.17 mordred)
  • Revision ID: brian@tangent.org-20090303185034-obr7tiwx8vyn0i7j
Merge Monty

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
 
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
 
3
 *
 
4
 *  Copyright (C) 2008 Sun Microsystems
 
5
 *
 
6
 *  This program is free software; you can redistribute it and/or modify
 
7
 *  it under the terms of the GNU General Public License as published by
 
8
 *  the Free Software Foundation; version 2 of the License.
 
9
 *
 
10
 *  This program is distributed in the hope that it will be useful,
 
11
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
 *  GNU General Public License for more details.
 
14
 *
 
15
 *  You should have received a copy of the GNU General Public License
 
16
 *  along with this program; if not, write to the Free Software
 
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
18
 */
 
19
 
 
20
#include "drizzled/server_includes.h"
 
21
#include "drizzled/plugin_registry_impl.h"
 
22
 
 
23
#include "drizzled/plugin.h"
 
24
 
 
25
#include <string>
 
26
#include <vector>
 
27
#include <map>
 
28
 
 
29
using namespace std;
 
30
 
 
31
st_plugin_int *Plugin_registry_impl::find(const LEX_STRING *name, int type)
 
32
{
 
33
  uint32_t i;
 
34
  string find_str(name->str,name->length);
 
35
  transform(find_str.begin(), find_str.end(), find_str.begin(), ::tolower);
 
36
 
 
37
  map<string, st_plugin_int *>::iterator map_iter;
 
38
  if (type == DRIZZLE_ANY_PLUGIN)
 
39
  {
 
40
    for (i= 0; i < DRIZZLE_MAX_PLUGIN_TYPE_NUM; i++)
 
41
    {
 
42
      map_iter= plugin_map[i].find(find_str);
 
43
      if (map_iter != plugin_map[i].end())
 
44
        return (*map_iter).second;
 
45
    }
 
46
  }
 
47
  else
 
48
  {
 
49
    map_iter= plugin_map[type].find(find_str);
 
50
    if (map_iter != plugin_map[type].end())
 
51
      return (*map_iter).second;
 
52
  }
 
53
  return(0);
 
54
}
 
55
 
 
56
void Plugin_registry_impl::add(st_mysql_plugin *handle, st_plugin_int *plugin)
 
57
{
 
58
  string add_str(plugin->name.str);
 
59
  transform(add_str.begin(), add_str.end(),
 
60
            add_str.begin(), ::tolower);
 
61
 
 
62
  plugin_map[handle->type][add_str]= plugin;
 
63
}
 
64
 
 
65
 
 
66
void Plugin_registry_impl::get_mask_list(uint32_t type,
 
67
                                         vector<st_plugin_int *> &plugins,
 
68
                                         uint32_t state_mask)
 
69
{
 
70
  st_plugin_int *plugin= NULL;
 
71
  plugins.reserve(plugin_map[type].size());
 
72
  map<string, st_plugin_int *>::iterator map_iter;
 
73
 
 
74
  for (map_iter= plugin_map[type].begin();
 
75
       map_iter != plugin_map[type].end();
 
76
       map_iter++)
 
77
  {
 
78
    plugin= (*map_iter).second;
 
79
    plugins.push_back(!(plugin->state & state_mask) ? plugin : NULL);
 
80
  }
 
81
}