#ifndef INCLUDE_COLLECTION_H #define INCLUDE_COLLECTION_H #print "[include ]\n" /*======================================================== = = = String = = = ========================================================*/ struct collection { int realloc_size, count; dword data_start; dword data_size; dword element_offset[4000]; int add(); int addn(); dword get(); void drop(); void increase_data_size(); }; :void collection::increase_data_size() { int filled_size; if (realloc_size<4096) realloc_size = 4096; if (!data_size) { data_size = realloc_size; data_start = malloc(realloc_size); } else { data_size = data_size + realloc_size; data_start = realloc(data_start, data_size); } } :int collection::add(dword in) { return addn(in, strlen(in)); } :int collection::addn(dword in, len) { if (count >= 4000) return 0; if (element_offset[count]+len+2 > data_size) { increase_data_size(); addn(in, len); return 1; } strncpy(data_start+element_offset[count], in, len); count++; element_offset[count] = element_offset[count-1] + len + 1; return 1; } :dword collection::get(dword pos) { if (pos<0) || (pos>=count) return 0; return data_start + element_offset[pos]; } :void collection::drop() { if (data_start) free(data_start); data_size = data_start = element_offset[count] = count = 0; } /*======================================================== = = = Integer = = = ========================================================*/ struct collection_int { int count; dword element[4096*3]; int add(); dword get(); dword get_last(); void pop(); void drop(); }; :int collection_int::add(dword in) { if (count >= 4096*3) return 0; element[count] = in; count++; return 1; } :dword collection_int::get(dword pos) { if (pos<0) || (pos>=count) return 0; return element[pos]; } :dword collection_int::get_last() { return element[count]; } :void collection_int::pop() { if (count>0) count--; } :void collection_int::drop() { element[0] = count = 0; } #endif