1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2008 Sun Microsystems
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.
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.
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
21
#ifndef DRIZZLED_FIELD_ITERATOR_H
22
#define DRIZZLED_FIELD_ITERATOR_H
24
#include <drizzled/sql_alloc.h>
25
#include <drizzled/sql_list.h>
26
#include <drizzled/natural_join_column.h>
32
Iterator over the fields of a generic table reference.
35
class Field_iterator: public Sql_alloc
38
Field_iterator() {} /* Remove gcc warning */
39
virtual ~Field_iterator() {}
40
virtual void set(TableList *)= 0;
41
virtual void next()= 0;
42
virtual bool end_of_fields()= 0; /* Return 1 at end of list */
43
virtual const char *name()= 0;
44
virtual Item *create_item(Session *)= 0;
45
virtual Field *field()= 0;
50
Iterator over the fields of a base table, view with temporary
54
class Field_iterator_table: public Field_iterator
58
Field_iterator_table() :ptr(0) {}
59
void set(TableList *table);
60
void set_table(Table *table);
61
void next() { ptr++; }
62
bool end_of_fields() { return *ptr == 0; }
64
Item *create_item(Session *session);
65
Field *field() { return *ptr; }
69
/* Iterator over the fields of a merge view. */
72
Field_iterator interface to the list of materialized fields of a
76
class Field_iterator_natural_join: public Field_iterator
78
List_iterator_fast<Natural_join_column> column_ref_it;
79
Natural_join_column *cur_column_ref;
81
Field_iterator_natural_join() :cur_column_ref(NULL) {}
82
~Field_iterator_natural_join() {}
83
void set(TableList *table);
85
bool end_of_fields() { return !cur_column_ref; }
86
const char *name() { return cur_column_ref->name(); }
87
Item *create_item(Session *session) { return cur_column_ref->create_item(session); }
88
Field *field() { return cur_column_ref->field(); }
89
Natural_join_column *column_ref() { return cur_column_ref; }
94
Generic iterator over the fields of an arbitrary table reference.
97
This class unifies the various ways of iterating over the columns
98
of a table reference depending on the type of SQL entity it
99
represents. If such an entity represents a nested table reference,
100
this iterator encapsulates the iteration over the columns of the
101
members of the table reference.
104
The implementation assumes that all underlying NATURAL/USING table
105
references already contain their result columns and are linked into
106
the list TableList::next_name_resolution_table.
109
class Field_iterator_table_ref: public Field_iterator
111
TableList *table_ref, *first_leaf, *last_leaf;
112
Field_iterator_table table_field_it;
113
Field_iterator_natural_join natural_join_it;
114
Field_iterator *field_it;
115
void set_field_iterator();
117
Field_iterator_table_ref() :field_it(NULL) {}
118
void set(TableList *table);
121
{ return (table_ref == last_leaf && field_it->end_of_fields()); }
122
const char *name() { return field_it->name(); }
123
const char *table_name();
124
const char *db_name();
125
Item *create_item(Session *session) { return field_it->create_item(session); }
126
Field *field() { return field_it->field(); }
127
Natural_join_column *get_or_create_column_ref(TableList *parent_table_ref);
128
Natural_join_column *get_natural_column_ref();
132
#endif /* DRIZZLED_FIELD_ITERATOR_H */