home *** CD-ROM | disk | FTP | other *** search
/ GEMini Atari / GEMini_Atari_CD-ROM_Walnut_Creek_December_1993.iso / files / gnu / g__inc / xobstack.h < prev    next >
Encoding:
C/C++ Source or Header  |  1993-07-23  |  4.5 KB  |  225 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 once
  23. #pragma interface
  24. #endif
  25. #define _Obstack_h 1
  26.  
  27. #include <std.h>
  28. #ifdef atarist
  29. #include <compiler.h>
  30. #endif
  31.  
  32. class Obstack
  33. {
  34.   struct _obstack_chunk
  35.   {
  36.     char*           limit;
  37.     _obstack_chunk* prev;
  38.     char            contents[4];
  39.   };
  40.  
  41. protected:
  42.   long              chunksize;
  43.   _obstack_chunk* chunk;
  44.   char*              objectbase;
  45.   char*              nextfree;
  46.   char*              chunklimit;
  47.   size_t             alignmentmask;
  48.  
  49.   void  _free(void* obj);
  50.   void  newchunk(size_t size);
  51.  
  52. public:
  53.         Obstack(size_t size = 4080, size_t alignment = 4); // 4080=4096-mallocslop
  54.  
  55.         ~Obstack();
  56.  
  57.   void* base();
  58.   void* next_free();
  59.   size_t   alignment_mask();
  60.   size_t   chunk_size();
  61.   size_t   size();
  62.   size_t   room();
  63.   int   contains(void* p);      // does Obstack hold pointer p?
  64.  
  65.   void  grow(const void* data, size_t size);
  66.   void  grow(const void* data, size_t size, char terminator);
  67.   void  grow(const char* s);
  68.   void  grow(char c);
  69.   void  grow_fast(char c);
  70.   void  blank(size_t size);
  71.   void  blank_fast(size_t size);
  72.  
  73.   void* finish();
  74.   void* finish(char terminator);
  75.  
  76.   void* copy(const void* data, size_t size);
  77.   void* copy(const void* data, size_t size, char terminator);
  78.   void* copy(const char* s);
  79.   void* copy(char c);
  80.   void* alloc(size_t size);
  81.  
  82.   void  free(void* obj);
  83.   void  shrink(size_t size = 1); // suggested by ken@cs.rochester.edu
  84.  
  85.   int   OK();                   // rep invariant
  86. };
  87.  
  88. #if defined(__OPTIMIZE__) || defined(USE_LIBGXX_INLINES)
  89.  
  90.  
  91. inline Obstack::~Obstack()
  92. {
  93.   _free(0); 
  94. }
  95.  
  96. inline void* Obstack::base()
  97. {
  98.   return objectbase; 
  99. }
  100.  
  101. inline void* Obstack::next_free()
  102. {
  103.   return nextfree; 
  104. }
  105.  
  106. inline size_t Obstack::alignment_mask()
  107. {
  108.   return alignmentmask; 
  109. }
  110.  
  111. inline size_t Obstack::chunk_size()
  112. {
  113.   return chunksize; 
  114. }
  115.  
  116. inline size_t Obstack::size()
  117. {
  118.   return nextfree - objectbase; 
  119. }
  120.  
  121. inline size_t Obstack::room()
  122. {
  123.   return chunklimit - nextfree; 
  124. }
  125.  
  126. inline void Obstack:: grow(const void* data, size_t size)
  127. {
  128.   if (nextfree+size > chunklimit) 
  129.     newchunk(size);
  130.   bcopy(data, nextfree, size);
  131.   nextfree += size; 
  132. }
  133.  
  134. inline void Obstack:: grow(const void* data, size_t size, char terminator)
  135. {
  136.   if (nextfree+size+1 > chunklimit) 
  137.     newchunk(size+1);
  138.   bcopy(data, nextfree, size);
  139.   nextfree += size; 
  140.   *(nextfree)++ = terminator; 
  141. }
  142.  
  143. inline void Obstack:: grow(const char* s)
  144. {
  145.   grow((void*)s, strlen(s), 0); 
  146. }
  147.  
  148. inline void Obstack:: grow(char c)
  149. {
  150.   if (nextfree+1 > chunklimit) 
  151.     newchunk(1); 
  152.   *(nextfree)++ = c; 
  153. }
  154.  
  155. inline void Obstack:: blank(size_t size)
  156. {
  157.   if (nextfree+size > chunklimit) 
  158.     newchunk(size);
  159.   nextfree += size; 
  160. }
  161.  
  162. inline void* Obstack::finish(char terminator)
  163. {
  164.   grow(terminator); 
  165.   return finish(); 
  166. }
  167.  
  168. inline void* Obstack::copy(const void* data, size_t size)
  169. {
  170.   grow (data, size);
  171.   return finish(); 
  172. }
  173.  
  174. inline void* Obstack::copy(const void* data, size_t size, char terminator)
  175. {
  176.   grow(data, size, terminator); 
  177.   return finish(); 
  178. }
  179.  
  180. inline void* Obstack::copy(const char* s)
  181. {
  182.   grow((void*)s, strlen(s), 0); 
  183.   return finish(); 
  184. }
  185.  
  186. inline void* Obstack::copy(char c)
  187. {
  188.   grow(c);
  189.   return finish(); 
  190. }
  191.  
  192. inline void* Obstack::alloc(size_t size)
  193. {
  194.   blank(size);
  195.   return finish(); 
  196. }
  197.  
  198. inline void Obstack:: free(void* obj)     
  199. {
  200.   if (obj >= (void*)chunk && obj<(void*)chunklimit)
  201.     nextfree = objectbase = (char *) obj;
  202.   else 
  203.     _free(obj); 
  204. }
  205.  
  206. inline void Obstack:: grow_fast(char c)
  207. {
  208.   *(nextfree)++ = c; 
  209. }
  210.  
  211. inline void Obstack:: blank_fast(size_t size)
  212. {
  213.   nextfree += size; 
  214. }
  215.  
  216. inline void Obstack:: shrink(size_t size) // from ken@cs.rochester.edu
  217. {
  218.   if (nextfree >= objectbase + size)
  219.     nextfree -= size;
  220. }
  221.  
  222. #endif
  223.  
  224. #endif
  225.