--- parser3/src/main/pa_table.C 2001/03/28 09:01:22 1.22 +++ parser3/src/main/pa_table.C 2002/08/01 11:26:51 1.48 @@ -1,28 +1,28 @@ /** @file Parser: table class. - Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) - - Author: Alexander Petrosyan (http://design.ru/paf) - - $Id: pa_table.C,v 1.22 2001/03/28 09:01:22 paf Exp $ + Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com) + Author: Alexandr Petrosian (http://paf.design.ru) */ -#include +static const char* IDENT_TABLE_C="$Id: pa_table.C,v 1.48 2002/08/01 11:26:51 paf Exp $"; + +//#include #include "pa_table.h" #include "pa_pool.h" +#include "pa_exception.h" Table::Table(Pool& apool, const String *aorigin_string, - Array *acolumns, + const Array *acolumns, int initial_rows) : Array(apool, initial_rows), forigin_string(aorigin_string), fcurrent(0), fcolumns(acolumns), - name2number(pool(), false) { + name2number(*NEW Hash(pool())) { if(fcolumns) for(int i=0; isize(); i++) { @@ -31,19 +31,48 @@ Table::Table(Pool& apool, } } -int Table::column_name2index(const String& column_name) const { - if(fcolumns) { // named - int column_number=name2number.get_int(column_name); - if(column_number) - return column_number-1; - else { - THROW(0, 0, - &column_name, +Table::Table(const Table& source) : + Array(source), + + forigin_string(source.forigin_string), + fcurrent(source.fcurrent), + fcolumns(source.fcolumns), + name2number(source.name2number) { + +} + +Table::Table(Pool& apool, const Table& source, int offset) : + Array(apool), + + forigin_string(source.forigin_string), + fcurrent(source.fcurrent), + fcolumns(source.fcolumns), + name2number(source.name2number) { + + append_array(source, offset); +} + +int Table::column_name2index(const String& column_name, bool bark) const { + if(fcolumns) {// named + int result=name2number.get_int(column_name)-1; // -1 = column not found + if(bark && result<0) + throw Exception("parser.runtime", + &column_name, "column not found"); - return 0; // unreached + return result; + } else { // nameless + char *error_pos; + const char *cstr=column_name.cstr(); + int result=(int)strtol(cstr, &error_pos, 0); + if(*error_pos/*not EOS*/) { + result=-1; + if(bark) + throw Exception("parser.runtime", + &column_name, + "invalid column number"); } - } else // nameless - return atoi(column_name.cstr()); + return result; + } } const String *Table::item(int column) const { @@ -55,19 +84,23 @@ const String *Table::item(int column) co return 0; // it's OK we don't have row|column, just return nothing } -bool Table::locate(const String& column, const String& value) { - int key_index=column_name2index(column); +bool Table::locate(int column, const String& value) { + int scurrent=fcurrent; for(fcurrent=0; fcurrent