~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/key_part_spec.h

  • Committer: Brian Aker
  • Date: 2010-02-11 22:43:58 UTC
  • Revision ID: brian@gaz-20100211224358-y0gdvnat2ahg4c1e
Disabling support for memcached plugins until we can test for version of
memcached.

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
 
 
21
#ifndef DRIZZLED_KEY_PART_SPEC_H
 
22
#define DRIZZLED_KEY_PART_SPEC_H
 
23
 
 
24
#include "drizzled/memory/sql_alloc.h"
 
25
#include "drizzled/lex_string.h"
 
26
 
 
27
namespace drizzled
 
28
{
 
29
 
 
30
namespace memory { class Root; }
 
31
 
 
32
class Item;
 
33
 
 
34
class Key_part_spec :public memory::SqlAlloc {
 
35
public:
 
36
  LEX_STRING field_name;
 
37
  uint32_t length;
 
38
  Key_part_spec(const LEX_STRING &name, uint32_t len)
 
39
    : field_name(name), length(len)
 
40
  {}
 
41
  Key_part_spec(const char *name, const size_t name_len, uint32_t len)
 
42
    : length(len)
 
43
  { field_name.str= const_cast<char *>(name); field_name.length= name_len; }
 
44
  bool operator==(const Key_part_spec& other) const;
 
45
  /**
 
46
    Construct a copy of this Key_part_spec. field_name is copied
 
47
    by-pointer as it is known to never change. At the same time
 
48
    'length' may be reset in mysql_prepare_create_table, and this
 
49
    is why we supply it with a copy.
 
50
 
 
51
    @return If out of memory, 0 is returned and an error is set in
 
52
    Session.
 
53
  */
 
54
  Key_part_spec *clone(memory::Root *mem_root) const
 
55
  {
 
56
    return new (mem_root) Key_part_spec(*this);
 
57
  }
 
58
};
 
59
 
 
60
} /* namespace drizzled */
 
61
 
 
62
#endif /* DRIZZLED_KEY_PART_SPEC_H */