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

ctypeList.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 ** ctypeList.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 "basic.h"
00034 
00035 /*@only@*/ ctypeList
00036 ctypeList_new ()
00037 {
00038   ctypeList s = (ctypeList) dmalloc (sizeof (*s));
00039   
00040   s->nelements = 0;
00041   s->nspace = ctypeListBASESIZE; 
00042   s->elements = (ctype *) dmalloc (sizeof (*s->elements) * ctypeListBASESIZE);
00043 
00044   return (s);
00045 }
00046 
00047 static void
00048 ctypeList_grow (/*@notnull@*/ ctypeList s)
00049 {
00050   int i;
00051   ctype *newelements;
00052   
00053   s->nspace += ctypeListBASESIZE; 
00054   newelements = (ctype *) dmalloc (sizeof (*newelements) * (s->nelements + s->nspace));
00055 
00056   if (newelements == (ctype *) 0)
00057     {
00058       llfatalerror (cstring_makeLiteral ("ctypeList_grow: out of memory!"));
00059     }
00060     
00061   for (i = 0; i < s->nelements; i++)
00062     {
00063       newelements[i] = s->elements[i];
00064     }
00065   
00066   sfree (s->elements);
00067   s->elements = newelements;
00068 }
00069 
00070 void ctypeList_addh (ctypeList s, ctype el)
00071 {
00072   llassert (ctypeList_isDefined (s));
00073   llassert (ctypeListBASESIZE > 0);
00074 
00075   if (s->nspace <= 0) ctypeList_grow (s);
00076   
00077   s->nspace--;
00078   s->elements[s->nelements] = el;
00079   s->nelements++;
00080 }
00081 
00082 /*@only@*/ cstring
00083 ctypeList_unparse (ctypeList ct)
00084 {
00085   cstring s = cstring_undefined;
00086   int i;
00087   bool first = TRUE;
00088 
00089   if (ctypeList_isUndefined (ct) || ctypeList_size (ct) == 0)
00090     {
00091       return (cstring_makeLiteral ("void"));
00092     }
00093 
00094   for (i = 0; i < ct->nelements; i++)
00095     {
00096       if (first)
00097         {
00098           s = cstring_copy (ctype_unparse (ct->elements[i]));
00099           first = FALSE;
00100         }
00101       else
00102         {
00103           s = message ("%q, %s", s, ctype_unparse (ct->elements[i]));
00104         }
00105     }
00106 
00107   return s;
00108 }
00109 
00110 void
00111 ctypeList_free (/*@only@*/ ctypeList s)
00112 {
00113   if (ctypeList_isDefined (s))
00114     {
00115       int i;
00116       for (i = 0; i < s->nelements; i++)
00117         {
00118           /*      ctype_free (s->elements[i]); */
00119         }
00120       
00121       sfree (s->elements); /* not quite!!! */
00122       sfree (s);
00123     }
00124 }
00125 
00126 
00127 
00128 
00129 
00130 
00131 

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