42 lines
		
	
	
		
			1014 B
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1014 B
		
	
	
	
		
			C++
		
	
	
namespace factor {
 | 
						|
 | 
						|
struct tenured_space : free_list_allocator<object> {
 | 
						|
  object_start_map starts;
 | 
						|
 | 
						|
  tenured_space(cell size, cell start)
 | 
						|
      : free_list_allocator<object>(size, start), starts(size, start) {}
 | 
						|
 | 
						|
  object* allot(cell size) {
 | 
						|
    object* obj = free_list_allocator<object>::allot(size);
 | 
						|
    if (obj) {
 | 
						|
      starts.record_object_start_offset(obj);
 | 
						|
      return obj;
 | 
						|
    }
 | 
						|
    return NULL;
 | 
						|
  }
 | 
						|
 | 
						|
  cell next_allocated_object_after(cell scan) {
 | 
						|
    while (scan != this->end && ((object*)scan)->free_p()) {
 | 
						|
      free_heap_block* free_block = (free_heap_block*)scan;
 | 
						|
      scan = (cell)free_block + free_block->size();
 | 
						|
    }
 | 
						|
    return scan == this->end ? 0 : scan;
 | 
						|
  }
 | 
						|
 | 
						|
  cell first_object() {
 | 
						|
    return next_allocated_object_after(this->start);
 | 
						|
  }
 | 
						|
 | 
						|
  cell next_object_after(cell scan) {
 | 
						|
    cell size = ((object*)scan)->size();
 | 
						|
    return next_allocated_object_after(scan + size);
 | 
						|
  }
 | 
						|
 | 
						|
  void sweep() {
 | 
						|
    free_list_allocator<object>::sweep();
 | 
						|
    starts.update_for_sweep(&this->state);
 | 
						|
  }
 | 
						|
};
 | 
						|
 | 
						|
}
 |