// // aegis - project change supervisor // Copyright (C) 2001, 2003-2006, 2008 Peter Miller // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see // . // #include #include void patch_line_list_constructor(patch_line_list_ty *this_thing) { this_thing->start_line_number = -1; this_thing->length = 0; this_thing->maximum = 0; this_thing->item = 0; } void patch_line_list_destructor(patch_line_list_ty *this_thing) { size_t j; for (j = 0; j < this_thing->length; ++j) patch_line_destructor(this_thing->item + j); delete [] this_thing->item; this_thing->start_line_number = -1; this_thing->length = 0; this_thing->maximum = 0; this_thing->item = 0; } void patch_line_list_append(patch_line_list_ty *this_thing, patch_line_type type, string_ty *value) { if (this_thing->length >= this_thing->maximum) { size_t new_maximum = this_thing->maximum * 2 + 8; patch_line_ty *new_item = new patch_line_ty [new_maximum]; for (size_t j = 0; j < this_thing->length; ++j) new_item[j] = this_thing->item[j]; delete [] this_thing->item; this_thing->item = new_item; this_thing->maximum = new_maximum; } patch_line_constructor( this_thing->item + this_thing->length++, type, value); }