/* * Copyright (C) 2003, 2004, 2005 Filip Pizlo. All rights reserved. * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY FILIP PIZLO ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL FILIP PIZLO OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "gpc_internal.h" #include "tsf_format.h" struct worklist { worklist_item_t *array; worklist_item_t *cur; size_t size; }; typedef struct worklist worklist_t; static inline tsf_bool_t worklist_init(worklist_t *worklist) { worklist->array = NULL; worklist->cur = NULL; worklist->size = 0; return tsf_true; } static inline void worklist_done(worklist_t *worklist) { if (worklist->array != NULL) { free(worklist->array); } } static inline worklist_item_t *worklist_push(worklist_t *worklist) { worklist_item_t *ret; if (worklist->cur == worklist->array+worklist->size) { if (worklist->array == NULL) { worklist->array = malloc(sizeof(worklist_item_t)); if (worklist->array == NULL) { tsf_set_errno("Could not malloc worklist array"); return NULL; } worklist->cur = worklist->array; } else { worklist_item_t *new_array = realloc(worklist->array, sizeof(worklist_item_t) * (1 + worklist->size)); if (new_array == NULL) { tsf_set_errno("Could not realloc worklist array"); return NULL; } worklist->cur += new_array-worklist->array; worklist->array = new_array; } worklist->size++; } ret = worklist->cur; worklist->cur++; return ret; } static inline worklist_item_t *worklist_pop(worklist_t *worklist) { if (worklist->cur == worklist->array) { return NULL; } return --worklist->cur; }