~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/optimizer/access_method/index.cc

Merge Stewart's dead code removal

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 Padraig O'Sullivan
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; either version 2 of the License, or
9
 
 *  (at your option) any later version.
10
 
 *
11
 
 *  This program is distributed in the hope that it will be useful,
12
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 
 *  GNU General Public License for more details.
15
 
 *
16
 
 *  You should have received a copy of the GNU General Public License
17
 
 *  along with this program; if not, write to the Free Software
18
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
 
 */
20
 
 
21
 
#include "config.h"
22
 
#include "drizzled/session.h"
23
 
#include "drizzled/join_table.h"
24
 
#include "drizzled/sql_select.h"
25
 
#include "drizzled/optimizer/access_method/index.h"
26
 
 
27
 
using namespace drizzled;
28
 
 
29
 
bool optimizer::Index::getStats(Table *table,
30
 
                                JoinTable *join_tab)
31
 
{
32
 
  table->status= STATUS_NO_RECORD;
33
 
  if (join_tab->select)
34
 
  {
35
 
    delete join_tab->select->quick;
36
 
    join_tab->select->quick= 0;
37
 
  }
38
 
 
39
 
  delete join_tab->quick;
40
 
  join_tab->quick= 0;
41
 
 
42
 
  if (table->covering_keys.test(join_tab->ref.key) && 
43
 
      ! table->no_keyread)
44
 
  {
45
 
    table->key_read= 1;
46
 
    table->cursor->extra(HA_EXTRA_KEYREAD);
47
 
  }
48
 
 
49
 
  if (join_tab->type == AM_REF)
50
 
  {
51
 
    join_tab->read_first_record= join_read_always_key;
52
 
    join_tab->read_record.read_record= join_tab->insideout_match_tab ?
53
 
      join_read_next_same_diff : join_read_next_same;
54
 
  }
55
 
  else
56
 
  {
57
 
    join_tab->read_first_record= join_read_always_key_or_null;
58
 
    join_tab->read_record.read_record= join_read_next_same_or_null;
59
 
  }
60
 
 
61
 
  return false;
62
 
}