File:  [parser3project] / parser3 / src / include / pa_array.h
Revision 1.7: download - view: text, annotated - select for diffs - revision graph
Mon Jan 29 15:56:03 2001 UTC (25 years, 5 months ago) by paf
Branches: MAIN
CVS tags: HEAD
Table started
would test
template Array now

/*
  $Id: pa_array.h,v 1.7 2001/01/29 15:56:03 paf Exp $
*/

/*

	Array               Chunk0
	======              ========
	head--------------->[ptr]
	append_here-------->[ptr]
	link_row            ........
			.			.
			.			[ptr]
			...........>[link to the next chunk]

*/

#ifndef PA_ARRAY_H
#define PA_ARRAY_H

#include <stddef.h>

#include "pa_types.h"

class Pool;

class Array {
public:

	typedef void *Item;

	enum {
		CR_INITIAL_ROWS_DEFAULT=10,
		CR_GROW_PERCENT=60
	};

public:

	void *operator new(size_t size, Pool *apool);
	Array(Pool *apool, int initial_rows=CR_INITIAL_ROWS_DEFAULT);

	int size() { return fused_rows; }
	Array& operator += (Item src);
	Array& operator += (Array& src);
	Item& operator [] (int index);

protected:

	// the pool I'm allocated on
	Pool *pool;

private:

	struct Chunk {
		// the number of rows in chunk
		int count;
		union Row {
			Item item;
			Chunk *link;  // link to the next chunk in chain
		} rows[1];
		// next rows are here
	}
		*head;  // the head chunk of the chunk chain

	// last allocated chunk
	// helps appending Arrays
	Chunk *tail;

	// next append would write to this record
	Chunk::Row *append_here;
	
	// the address of place where lies address 
	// of the link to the next chunk to allocate
	Chunk::Row *link_row;

private:

	// array size
	int fused_rows;

	int cache_chunk_base;
	Chunk *cache_chunk;
	
private:

	bool chunk_is_full() {
		return append_here == link_row;
	}
	void expand(int chunk_rows);

private: //disabled

	Array(Array&) {}
	Array& operator = (Array&) { return *this; }
};

#endif

E-mail: