/* * Copyright 1987, 1988 by MIT Student Information Processing Board * * Permission to use, copy, modify, and distribute this software and * its documentation for any purpose is hereby granted, provided that * the names of M.I.T. and the M.I.T. S.I.P.B. not be used in * advertising or publicity pertaining to distribution of the software * without specific, written prior permission. M.I.T. and the * M.I.T. S.I.P.B. make no representations about the suitability of * this software for any purpose. It is provided "as is" without * express or implied warranty. */ #include "config.h" #ifdef HAVE_ERRNO_H #include <errno.h> #endif #include "ss_internal.h" #define ssrt ss_request_table /* for some readable code... */ void ss_add_request_table(int sci_idx, ssrt *rqtbl_ptr, int position, int *code_ptr) { register ss_data *info; register int i, size; ssrt **t; info = ss_info(sci_idx); for (size=0; info->rqt_tables[size] != (ssrt *)NULL; size++) ; /* size == C subscript of NULL == #elements */ size += 2; /* new element, and NULL */ t = (ssrt **)realloc(info->rqt_tables, (unsigned)size*sizeof(ssrt *)); if (t == (ssrt **)NULL) { *code_ptr = errno; return; } info->rqt_tables = t; if (position > size - 2) position = size - 2; if (size > 1) for (i = size - 2; i >= position; i--) info->rqt_tables[i+1] = info->rqt_tables[i]; info->rqt_tables[position] = rqtbl_ptr; info->rqt_tables[size-1] = (ssrt *)NULL; *code_ptr = 0; } void ss_delete_request_table(int sci_idx, ssrt *rqtbl_ptr, int *code_ptr) { register ss_data *info; register ssrt **rt1, **rt2; *code_ptr = SS_ET_TABLE_NOT_FOUND; info = ss_info(sci_idx); rt1 = info->rqt_tables; for (rt2 = rt1; *rt1; rt1++) { if (*rt1 != rqtbl_ptr) { *rt2++ = *rt1; *code_ptr = 0; } } *rt2 = (ssrt *)NULL; return; }