15e9cd1aeSAssar Westerlund /* 2adb0ddaeSAssar Westerlund * Copyright (c) 1997, 1998, 2001 Kungliga Tekniska H�gskolan 35e9cd1aeSAssar Westerlund * (Royal Institute of Technology, Stockholm, Sweden). 45e9cd1aeSAssar Westerlund * All rights reserved. 55e9cd1aeSAssar Westerlund * 65e9cd1aeSAssar Westerlund * Redistribution and use in source and binary forms, with or without 75e9cd1aeSAssar Westerlund * modification, are permitted provided that the following conditions 85e9cd1aeSAssar Westerlund * are met: 95e9cd1aeSAssar Westerlund * 105e9cd1aeSAssar Westerlund * 1. Redistributions of source code must retain the above copyright 115e9cd1aeSAssar Westerlund * notice, this list of conditions and the following disclaimer. 125e9cd1aeSAssar Westerlund * 135e9cd1aeSAssar Westerlund * 2. Redistributions in binary form must reproduce the above copyright 145e9cd1aeSAssar Westerlund * notice, this list of conditions and the following disclaimer in the 155e9cd1aeSAssar Westerlund * documentation and/or other materials provided with the distribution. 165e9cd1aeSAssar Westerlund * 175e9cd1aeSAssar Westerlund * 3. Neither the name of the Institute nor the names of its contributors 185e9cd1aeSAssar Westerlund * may be used to endorse or promote products derived from this software 195e9cd1aeSAssar Westerlund * without specific prior written permission. 205e9cd1aeSAssar Westerlund * 215e9cd1aeSAssar Westerlund * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND 225e9cd1aeSAssar Westerlund * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 235e9cd1aeSAssar Westerlund * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 245e9cd1aeSAssar Westerlund * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE 255e9cd1aeSAssar Westerlund * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 265e9cd1aeSAssar Westerlund * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 275e9cd1aeSAssar Westerlund * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 285e9cd1aeSAssar Westerlund * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 295e9cd1aeSAssar Westerlund * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 305e9cd1aeSAssar Westerlund * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 315e9cd1aeSAssar Westerlund * SUCH DAMAGE. 325e9cd1aeSAssar Westerlund */ 335e9cd1aeSAssar Westerlund 345e9cd1aeSAssar Westerlund #ifdef HAVE_CONFIG_H 355e9cd1aeSAssar Westerlund #include <config.h> 36adb0ddaeSAssar Westerlund RCSID("$Id: error.c,v 1.15 2001/02/28 20:00:13 joda Exp $"); 375e9cd1aeSAssar Westerlund #endif 385e9cd1aeSAssar Westerlund #include <stdio.h> 395e9cd1aeSAssar Westerlund #include <stdlib.h> 405e9cd1aeSAssar Westerlund #include <string.h> 415e9cd1aeSAssar Westerlund #include <com_right.h> 425e9cd1aeSAssar Westerlund 435e9cd1aeSAssar Westerlund const char * 445e9cd1aeSAssar Westerlund com_right(struct et_list *list, long code) 455e9cd1aeSAssar Westerlund { 465e9cd1aeSAssar Westerlund struct et_list *p; 475e9cd1aeSAssar Westerlund for (p = list; p; p = p->next) { 485e9cd1aeSAssar Westerlund if (code >= p->table->base && code < p->table->base + p->table->n_msgs) 495e9cd1aeSAssar Westerlund return p->table->msgs[code - p->table->base]; 505e9cd1aeSAssar Westerlund } 515e9cd1aeSAssar Westerlund return NULL; 525e9cd1aeSAssar Westerlund } 535e9cd1aeSAssar Westerlund 545e9cd1aeSAssar Westerlund struct foobar { 555e9cd1aeSAssar Westerlund struct et_list etl; 565e9cd1aeSAssar Westerlund struct error_table et; 575e9cd1aeSAssar Westerlund }; 585e9cd1aeSAssar Westerlund 595e9cd1aeSAssar Westerlund void 605e9cd1aeSAssar Westerlund initialize_error_table_r(struct et_list **list, 615e9cd1aeSAssar Westerlund const char **messages, 625e9cd1aeSAssar Westerlund int num_errors, 635e9cd1aeSAssar Westerlund long base) 645e9cd1aeSAssar Westerlund { 65adb0ddaeSAssar Westerlund struct et_list *et, **end; 665e9cd1aeSAssar Westerlund struct foobar *f; 67adb0ddaeSAssar Westerlund for (end = list, et = *list; et; end = &et->next, et = et->next) 685e9cd1aeSAssar Westerlund if (et->table->msgs == messages) 695e9cd1aeSAssar Westerlund return; 705e9cd1aeSAssar Westerlund f = malloc(sizeof(*f)); 715e9cd1aeSAssar Westerlund if (f == NULL) 725e9cd1aeSAssar Westerlund return; 735e9cd1aeSAssar Westerlund et = &f->etl; 745e9cd1aeSAssar Westerlund et->table = &f->et; 755e9cd1aeSAssar Westerlund et->table->msgs = messages; 765e9cd1aeSAssar Westerlund et->table->n_msgs = num_errors; 775e9cd1aeSAssar Westerlund et->table->base = base; 78adb0ddaeSAssar Westerlund et->next = NULL; 79adb0ddaeSAssar Westerlund *end = et; 805e9cd1aeSAssar Westerlund } 815e9cd1aeSAssar Westerlund 825e9cd1aeSAssar Westerlund 835e9cd1aeSAssar Westerlund void 845e9cd1aeSAssar Westerlund free_error_table(struct et_list *et) 855e9cd1aeSAssar Westerlund { 865e9cd1aeSAssar Westerlund while(et){ 875e9cd1aeSAssar Westerlund struct et_list *p = et; 885e9cd1aeSAssar Westerlund et = et->next; 895e9cd1aeSAssar Westerlund free(p); 905e9cd1aeSAssar Westerlund } 915e9cd1aeSAssar Westerlund } 92