/* * Copyright (c) 1998 The University of Utah and * the Computer Systems Laboratory at the University of Utah (CSL). * * This file is part of Flick, the Flexible IDL Compiler Kit. * * Flick 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 2 of the License, or * (at your option) any later version. * * Flick 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 Flick; see the file COPYING. If not, write to * the Free Software Foundation, 59 Temple Place #330, Boston, MA 02111, USA. */ #include #include #include cast_init_array null_init_array = { 0, 0 }; cast_init_array cast_set_init_array(cast_init_array *array, cast_init init, ...) { cast_init_array new_array; va_list args; cast_init init_arg; unsigned int i; if (!array) { array = &new_array; *array = null_init_array; } init_arg = init; va_start(args, init); for (i = 0; init_arg; i++) { if (i == array->cast_init_array_len) { array->cast_init_array_len += 4; array->cast_init_array_val = (cast_init *)mustrealloc( array->cast_init_array_val, array->cast_init_array_len * sizeof(cast_init)); } array->cast_init_array_val[i] = init_arg; init_arg = va_arg(args, cast_init); } va_end(args); if (i != array->cast_init_array_len) { array->cast_init_array_len = i; array->cast_init_array_val = (cast_init *)mustrealloc( array->cast_init_array_val, array->cast_init_array_len * sizeof(cast_init)); } return *array; } /* End of file. */