Annotation of parser3/src/main/pa_table.C, revision 1.56
1.14 paf 1: /** @file
1.15 paf 2: Parser: table class.
3:
1.56 ! paf 4: Copyright (c) 2001-2003 ArtLebedev Group (http://www.artlebedev.com)
1.44 paf 5: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
1.48 paf 6: */
1.15 paf 7:
1.56 ! paf 8: static const char* IDENT_TABLE_C="$Date: 2003/04/14 14:03:11 $";
1.1 paf 9:
1.56 ! paf 10: #include "pa_table.h"
1.2 paf 11:
1.25 paf 12: #include "pa_exception.h"
1.1 paf 13:
1.56 ! paf 14: Table::Table(columns_type acolumns, size_t initial_rows):
! 15: Array<element_type>(initial_rows),
1.13 paf 16:
1.5 paf 17: fcurrent(0),
18: fcolumns(acolumns),
1.56 ! paf 19: name2number(new name2number_hash_class) {
1.1 paf 20:
1.56 ! paf 21: if(fcolumns) {
! 22: size_t fcolumns_count=fcolumns->count();
! 23: size_t number=1;
! 24: for(Array_iterator<const String*> i(*fcolumns); i.has_next(); ) {
! 25: const String& name=*i.next();
! 26: name2number->put(name, number++);
1.1 paf 27: }
1.56 ! paf 28: }
1.42 paf 29: }
30:
1.56 ! paf 31: Table::Table(const Table& src, Action_options& options) :
! 32: Array<element_type>(options.limit==ARRAY_OPTION_LIMIT_ALL?0:options.limit/*may be more than needed, no harm done*/),
1.42 paf 33:
1.51 paf 34: fcurrent(0),
1.56 ! paf 35: fcolumns(src.fcolumns),
! 36: name2number(src.name2number) {
1.42 paf 37:
1.56 ! paf 38: append(src, options.offset, options.limit, options.reverse);
1.2 paf 39: }
40:
1.29 paf 41: int Table::column_name2index(const String& column_name, bool bark) const {
42: if(fcolumns) {// named
1.56 ! paf 43: int result=name2number->get(column_name)-1; // -1 = column not found
1.29 paf 44: if(bark && result<0)
1.45 paf 45: throw Exception("parser.runtime",
1.29 paf 46: &column_name,
47: "column not found");
48: return result;
1.56 ! paf 49: } else // nameless
! 50: return column_name.as_int();
1.21 paf 51: }
52:
1.56 ! paf 53: const String* Table::item(size_t column) {
1.21 paf 54: if(valid(fcurrent)) {
1.56 ! paf 55: element_type row=get(fcurrent);
! 56: if(column>=0 && column<row->count()) // proper index?
! 57: return row->get(column);
1.21 paf 58: }
59: return 0; // it's OK we don't have row|column, just return nothing
60: }
61:
1.54 paf 62: #ifndef DOXYGEN
63: struct Locate_int_string_info {
64: int column;
65: const String* value;
66: };
67: #endif
68: bool locate_int_string(Table& self, void* ainfo) {
69: Locate_int_string_info& info=*static_cast<Locate_int_string_info*>(ainfo);
70:
71: const String *item_value=self.item(info.column);
72: return item_value && *item_value==*info.value;
73: }
74:
75: bool Table::locate(int column, const String& value,
76: Table::Action_options& options) {
77: Locate_int_string_info info={column, &value};
1.56 ! paf 78: return table_first_that(locate_int_string, &info, options);
1.54 paf 79: }
80:
81: bool Table::locate(const String& column, const String& value,
82: Table::Action_options& options) {
83: return locate(column_name2index(column, true), value, options);
1.22 paf 84: }
85:
1.41 paf 86: void Table::offset(bool absolute, int offset) {
1.56 ! paf 87: if(size_t lcount=count())
! 88: fcurrent=((absolute?0:fcurrent)+offset+lcount)%lcount;
1.1 paf 89: }
E-mail: