--- parser3/src/include/pa_array.h 2001/04/26 14:55:25 1.36 +++ parser3/src/include/pa_array.h 2001/05/16 16:48:56 1.39 @@ -5,7 +5,7 @@ Author: Alexander Petrosyan (http://design.ru/paf) - $Id: pa_array.h,v 1.36 2001/04/26 14:55:25 paf Exp $ + $Id: pa_array.h,v 1.39 2001/05/16 16:48:56 parser Exp $ */ #ifndef PA_ARRAY_H @@ -53,8 +53,8 @@ public: typedef bool (*First_that_func)(Item *value, void *info); enum { - CR_INITIAL_ROWS_DEFAULT=10, ///< default preallocated row count - CR_GROW_PERCENT=60 ///< each time the Array chunk_is_full() array expanded() + CR_INITIAL_ROWS_DEFAULT=3, ///< default preallocated row count + CR_GROW_COUNT=3 ///< each time the Array chunk_is_full() array expanded() }; public: @@ -81,9 +81,11 @@ public: int size() const { return fused_rows; } /// append Item to array Array& operator += (Item *src); + /// append int value to array + Array& operator += (int value) { return *this+=reinterpret_cast(value); } /// dirty hack to allow constant items storage. I long for Array - Array& operator += (const Item *src) { return *this+=const_cast(src); } + Array& operator += (const Item *src) { return *this+=const_cast(src); } /// append other Array portion to this one. starting from offset Array& append_array(const Array& src, int offset=0); @@ -108,6 +110,8 @@ public: } Item *get(int index) const; + int get_int(int index) const { return reinterpret_cast(get(index)); } + void put(int index, Item *item); /// convinient way to get strings from Array. I long for Array const String *get_string(int index) const { @@ -170,6 +174,7 @@ private: bool chunk_is_full() { return append_here == link_row; } + int expand_times; void expand(int chunk_rows); private: //disabled