Main Page   Alphabetical List   Compound List   File List   Compound Members   File Members  

storeRefNodeList.c

Go to the documentation of this file.
00001 /*
00002 ** LCLint - annotation-assisted static program checker
00003 ** Copyright (C) 1994-2000 University of Virginia,
00004 **         Massachusetts Institute of Technology
00005 **
00006 ** This program is free software; you can redistribute it and/or modify it
00007 ** under the terms of the GNU General Public License as published by the
00008 ** Free Software Foundation; either version 2 of the License, or (at your
00009 ** option) any later version.
00010 ** 
00011 ** This program is distributed in the hope that it will be useful, but
00012 ** WITHOUT ANY WARRANTY; without even the implied warranty of
00013 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00014 ** General Public License for more details.
00015 ** 
00016 ** The GNU General Public License is available from http://www.gnu.org/ or
00017 ** the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
00018 ** MA 02111-1307, USA.
00019 **
00020 ** For information on lclint: lclint-request@cs.virginia.edu
00021 ** To report a bug: lclint-bug@cs.virginia.edu
00022 ** For more information: http://lclint.cs.virginia.edu
00023 */
00024 /*
00025 ** storeRefNodeList.c
00026 **
00027 ** based on list_template.c
00028 **
00029 ** where T has T_equal (or change this) and T_unparse
00030 */
00031 
00032 # include "lclintMacros.nf"
00033 # include "llbasic.h"
00034 
00035 /*@only@*/ storeRefNodeList
00036 storeRefNodeList_new ()
00037 {
00038   storeRefNodeList s = (storeRefNodeList) dmalloc (sizeof (*s));
00039 
00040   s->nelements = 0;
00041   s->nspace = storeRefNodeListBASESIZE;
00042   s->elements = (storeRefNode *) 
00043     dmalloc (sizeof (*s->elements) * storeRefNodeListBASESIZE);
00044 
00045   return (s);
00046 }
00047 
00048 static void
00049 storeRefNodeList_grow (storeRefNodeList s)
00050 {
00051   int i;
00052   storeRefNode *newelements; 
00053 
00054   s->nspace += storeRefNodeListBASESIZE;
00055 
00056   newelements = (storeRefNode *) dmalloc (sizeof (*newelements)
00057                                           * (s->nelements + s->nspace));
00058 
00059   for (i = 0; i < s->nelements; i++)
00060     {
00061       newelements[i] = s->elements[i]; 
00062     }
00063 
00064   sfree (s->elements); 
00065   s->elements = newelements;
00066 }
00067 
00068 storeRefNodeList
00069 storeRefNodeList_add (storeRefNodeList s, storeRefNode el)
00070 {
00071   if (s->nspace <= 0)
00072     storeRefNodeList_grow (s);
00073 
00074   s->nspace--;
00075   s->elements[s->nelements] = el;
00076   s->nelements++;
00077 
00078   return s;
00079 }
00080 
00081 /*@only@*/ storeRefNodeList 
00082 storeRefNodeList_copy (storeRefNodeList s)
00083 {
00084   storeRefNodeList r = storeRefNodeList_new ();
00085 
00086   storeRefNodeList_elements (s, x)
00087     {
00088       r = storeRefNodeList_add (r, storeRefNode_copy (x));
00089     } end_storeRefNodeList_elements;
00090 
00091   return r;
00092 }
00093 
00094 /*@only@*/ cstring
00095 storeRefNodeList_unparse (storeRefNodeList s)
00096 {
00097   bool first = TRUE;
00098   cstring st = cstring_undefined;
00099 
00100   storeRefNodeList_elements (s, current)
00101   {
00102     if (first)
00103       {
00104         first = FALSE;
00105       }
00106     else
00107       {
00108         st = message ("%q, ", st);
00109       }
00110 
00111     switch (current->kind)
00112       {
00113       case SRN_OBJ:
00114         st = message ("%qobj", st);
00115         /*@switchbreak@*/ break;
00116       case SRN_TERM:
00117         st = message ("%q%q", st, termNode_unparse (current->content.term));
00118         /*@switchbreak@*/ break;
00119       case SRN_TYPE:
00120         st = message ("%q%q", st, lclTypeSpecNode_unparse (current->content.type));
00121         /*@switchbreak@*/ break;
00122       case SRN_SPECIAL:
00123         st = message ("%q%q", st, sRef_unparse (current->content.ref));
00124         /*@switchbreak@*/ break;
00125       }
00126   } end_storeRefNodeList_elements;
00127 
00128   return st;
00129 }
00130 
00131 void
00132 storeRefNodeList_free (storeRefNodeList s)
00133 {
00134   int i;
00135   for (i = 0; i < s->nelements; i++)
00136     {
00137       storeRefNode_free (s->elements[i]);
00138     }
00139 
00140   sfree (s->elements);
00141   sfree (s);
00142 }

Generated at Fri Nov 3 18:57:45 2000 for LCLint by doxygen1.2.3 written by Dimitri van Heesch, © 1997-2000