home *** CD-ROM | disk | FTP | other *** search
/ Computer Club Elmshorn Atari PD / CCE_PD.iso / pc / 0400 / CCE_0423.ZIP / CCE_0423.PD / GPINCL13.ZOO / xobstack.h < prev    next >
C/C++ Source or Header  |  1992-10-01  |  5KB  |  220 lines

  1. // This may look like C code, but it is really -*- C++ -*-
  2. /* 
  3. Copyright (C) 1988 Free Software Foundation
  4.     written by Doug Lea (dl@rocky.oswego.edu)
  5.  
  6. This file is part of the GNU C++ Library.  This library is free
  7. software; you can redistribute it and/or modify it under the terms of
  8. the GNU Library General Public License as published by the Free
  9. Software Foundation; either version 2 of the License, or (at your
  10. option) any later version.  This library is distributed in the hope
  11. that it will be useful, but WITHOUT ANY WARRANTY; without even the
  12. implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  13. PURPOSE.  See the GNU Library General Public License for more details.
  14. You should have received a copy of the GNU Library General Public
  15. License along with this library; if not, write to the Free Software
  16. Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  17. */
  18.  
  19.  
  20. #ifndef _Obstack_h
  21. #ifdef __GNUG__
  22. #pragma interface
  23. #endif
  24. #define _Obstack_h 1
  25.  
  26. #include <std.h>
  27. #ifdef atarist
  28. # include <compiler.h>
  29. #endif
  30.  
  31. class Obstack
  32. {
  33.   struct _obstack_chunk
  34.   {
  35.     char*           limit;
  36.     _obstack_chunk* prev;
  37.     char            contents[4];
  38.   };
  39.  
  40. protected:
  41.   long              chunksize;
  42.   _obstack_chunk* chunk;
  43.   char*              objectbase;
  44.   char*              nextfree;
  45.   char*              chunklimit;
  46.   size_t          alignmentmask;
  47.  
  48.   void  _free(void* obj);
  49.   void  newchunk(size_t size);
  50.  
  51. public:
  52.         Obstack(size_t size = 4080, size_t alignment = 4); // 4080=4096-mallocslop
  53.  
  54.         ~Obstack();
  55.  
  56.   void* base();
  57.   void* next_free();
  58.   size_t   alignment_mask();
  59.   size_t   chunk_size();
  60.   size_t   size();
  61.   size_t   room();
  62.   int   contains(void* p);      // does Obstack hold pointer p?
  63.  
  64.   void  grow(const void* data, size_t size);
  65.   void  grow(const void* data, size_t size, char terminator);
  66.   void  grow(const char* s);
  67.   void  grow(char c);
  68.   void  grow_fast(char c);
  69.   void  blank(size_t size);
  70.   void  blank_fast(size_t size);
  71.  
  72.   void* finish();
  73.   void* finish(char terminator);
  74.  
  75.   void* copy(const void* data, size_t size);
  76.   void* copy(const void* data, size_t size, char terminator);
  77.   void* copy(const char* s);
  78.   void* copy(char c);
  79.   void* alloc(size_t size);
  80.  
  81.   void  free(void* obj);
  82.   void  shrink(size_t size = 1); // suggested by ken@cs.rochester.edu
  83.  
  84.   int   OK();                   // rep invariant
  85. };
  86.  
  87.  
  88. inline Obstack::~Obstack()
  89. {
  90.   _free(0); 
  91. }
  92.  
  93. inline void* Obstack::base()
  94. {
  95.   return objectbase; 
  96. }
  97.  
  98. inline void* Obstack::next_free()
  99. {
  100.   return nextfree; 
  101. }
  102.  
  103. inline size_t Obstack::alignment_mask()
  104. {
  105.   return alignmentmask; 
  106. }
  107.  
  108. inline size_t Obstack::chunk_size()
  109. {
  110.   return chunksize; 
  111. }
  112.  
  113. inline size_t Obstack::size()
  114. {
  115.   return nextfree - objectbase; 
  116. }
  117.  
  118. inline size_t Obstack::room()
  119. {
  120.   return chunklimit - nextfree; 
  121. }
  122.  
  123. inline void Obstack:: grow(const void* data, size_t size)
  124. {
  125.   if (nextfree+size > chunklimit) 
  126.     newchunk(size);
  127.   bcopy(data, nextfree, size);
  128.   nextfree += size; 
  129. }
  130.  
  131. inline void Obstack:: grow(const void* data, size_t size, char terminator)
  132. {
  133.   if (nextfree+size+1 > chunklimit) 
  134.     newchunk(size+1);
  135.   bcopy(data, nextfree, size);
  136.   nextfree += size; 
  137.   *(nextfree)++ = terminator; 
  138. }
  139.  
  140. inline void Obstack:: grow(const char* s)
  141. {
  142.   grow((const void*)s, strlen(s), 0); 
  143. }
  144.  
  145. inline void Obstack:: grow(char c)
  146. {
  147.   if (nextfree+1 > chunklimit) 
  148.     newchunk(1); 
  149.   *(nextfree)++ = c; 
  150. }
  151.  
  152. inline void Obstack:: blank(size_t size)
  153. {
  154.   if (nextfree+size > chunklimit) 
  155.     newchunk(size);
  156.   nextfree += size; 
  157. }
  158.  
  159. inline void* Obstack::finish(char terminator)
  160. {
  161.   grow(terminator); 
  162.   return finish(); 
  163. }
  164.  
  165. inline void* Obstack::copy(const void* data, size_t size)
  166. {
  167.   grow (data, size);
  168.   return finish(); 
  169. }
  170.  
  171. inline void* Obstack::copy(const void* data, size_t size, char terminator)
  172. {
  173.   grow(data, size, terminator); 
  174.   return finish(); 
  175. }
  176.  
  177. inline void* Obstack::copy(const char* s)
  178. {
  179.   grow((const void*)s, strlen(s), 0); 
  180.   return finish(); 
  181. }
  182.  
  183. inline void* Obstack::copy(char c)
  184. {
  185.   grow(c);
  186.   return finish(); 
  187. }
  188.  
  189. inline void* Obstack::alloc(size_t size)
  190. {
  191.   blank(size);
  192.   return finish(); 
  193. }
  194.  
  195. inline void Obstack:: free(void* obj)     
  196. {
  197.   if (obj >= (void*)chunk && obj<(void*)chunklimit)
  198.     nextfree = objectbase = (char *) obj;
  199.   else 
  200.     _free(obj); 
  201. }
  202.  
  203. inline void Obstack:: grow_fast(char c)
  204. {
  205.   *(nextfree)++ = c; 
  206. }
  207.  
  208. inline void Obstack:: blank_fast(size_t size)
  209. {
  210.   nextfree += size; 
  211. }
  212.  
  213. inline void Obstack:: shrink(size_t size) // from ken@cs.rochester.edu
  214. {
  215.   if (nextfree >= objectbase + size)
  216.     nextfree -= size;
  217. }
  218.  
  219. #endif
  220.