~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/key_part_spec.h

  • Committer: Monty Taylor
  • Date: 2008-08-16 21:06:22 UTC
  • Revision ID: monty@inaugust.com-20080816210622-zpnn13unyinqzn72
Updated po files.

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