~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/module/context.h

  • Committer: Jay Pipes
  • Date: 2009-01-30 04:01:12 UTC
  • mto: This revision was merged to the branch mainline in revision 830.
  • Revision ID: jpipes@serialcoder-20090130040112-svbn774guj98pwi4
To remain in compatibility with MySQL, added ability to interpret
decimal arguments as datetime strings for temporal functions.

Fixed YEAR(), MONTH(), DAYOFMONTH(), DAYOFYEAR(), HOUR(), MINUTE(), SECOND(), and MICROSECOND()
to accept decimal parameters and interpret them the same way as MySQL.

Fixed an issue with the TemporalFormat::matches() method which was 
incorrectly assuming all microsecond arguments were specified as 6 digits.
Added power of 10 multiplier to usecond calculation. This fixes issues with
failures in type_date and func_sapdb test cases.

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) 2010 Monty Taylor
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
 
#ifndef DRIZZLED_MODULE_CONTEXT_H
21
 
#define DRIZZLED_MODULE_CONTEXT_H
22
 
 
23
 
/**
24
 
 * @file Defines a Plugin Context
25
 
 *
26
 
 * A module::Context object is a proxy object containing state information
27
 
 * about the plugin being registered that knows how to perform registration
28
 
 * actions.
29
 
 *
30
 
 * The plugin registration system creates a new module::Context for each
31
 
 * module::Module during the initializtion phase and passes a reference to
32
 
 * the module::Context to the module's init method. This allows the plugin
33
 
 * to call registration methods without having access to larger module::Registry
34
 
 * calls. It also provides a filter layer through which calls are made in order
35
 
 * to force things like proper name prefixing and the like.
36
 
 */
37
 
 
38
 
#include "drizzled/module/registry.h"
39
 
 
40
 
namespace drizzled
41
 
{
42
 
 
43
 
class sys_var;
44
 
 
45
 
namespace module
46
 
{
47
 
 
48
 
class Module;
49
 
class option_map;
50
 
 
51
 
class Context
52
 
{
53
 
private:
54
 
  module::Registry &registry;
55
 
  module::Module *module;
56
 
 
57
 
  Context(const Context&);
58
 
  Context& operator=(const Context&);
59
 
public:
60
 
 
61
 
  Context(module::Registry &registry_arg,
62
 
          module::Module *module_arg) :
63
 
     registry(registry_arg),
64
 
     module(module_arg)
65
 
  { }
66
 
 
67
 
  template<class T>
68
 
  void add(T *plugin)
69
 
  {
70
 
    plugin->setModule(module);
71
 
    registry.add(plugin);
72
 
  }
73
 
 
74
 
  template<class T>
75
 
  void remove(T *plugin)
76
 
  {
77
 
    registry.remove(plugin);
78
 
  }
79
 
 
80
 
  void registerVariable(sys_var *var);
81
 
 
82
 
  option_map getOptions();
83
 
 
84
 
  static std::string prepend_name(std::string module_name,
85
 
                                  const std::string &var_name);
86
 
};
87
 
 
88
 
 
89
 
} /* namespace module */
90
 
} /* namespace drizzled */
91
 
 
92
 
#endif /* DRIZZLED_MODULE_CONTEXT_H */