/* * 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_expr_array null_expr_array = { 0, 0 }; cast_expr_array cast_set_expr_array(cast_expr_array *array, cast_expr expr, ...) { cast_expr_array new_array; va_list args; cast_expr expr_arg; unsigned int i; if (!array) { array = &new_array; *array = null_expr_array; } expr_arg = expr; va_start(args, expr); for (i = 0; expr_arg; i++) { if (i == array->cast_expr_array_len) { array->cast_expr_array_len += 4; array->cast_expr_array_val = (cast_expr *)mustrealloc( array->cast_expr_array_val, array->cast_expr_array_len * sizeof(cast_expr)); } array->cast_expr_array_val[i] = expr_arg; expr_arg = va_arg(args, cast_expr); } va_end(args); if (i != array->cast_expr_array_len) { array->cast_expr_array_len = i; array->cast_expr_array_val = (cast_expr *)mustrealloc( array->cast_expr_array_val, array->cast_expr_array_len * sizeof(cast_expr)); } return *array; } /* End of file. */