#ifndef BOXED_REGION_H #define BOXED_REGION_H #include struct type_desc; class memory_region; struct rust_opaque_box; struct rust_env; /* Tracks the data allocated by a particular task in the '@' region. * Currently still relies on the standard malloc as a backing allocator, but * this could be improved someday if necessary. Every allocation must provide * a type descr which describes the payload (what follows the header). */ class boxed_region { private: rust_env *env; memory_region *backing_region; rust_opaque_box *live_allocs; size_t align_to(size_t v, size_t align) { size_t alignm1 = align - 1; v += alignm1; v &= ~alignm1; return v; } public: boxed_region(rust_env *e, memory_region *br) : env(e) , backing_region(br) , live_allocs(NULL) {} rust_opaque_box *first_live_alloc() { return live_allocs; } rust_opaque_box *malloc(type_desc *td, size_t body_size); rust_opaque_box *calloc(type_desc *td, size_t body_size); rust_opaque_box *realloc(rust_opaque_box *box, size_t new_size); void free(rust_opaque_box *box); }; #endif /* BOXED_REGION_H */ // // Local Variables: // mode: C++ // fill-column: 78; // indent-tabs-mode: nil // c-basic-offset: 4 // buffer-file-coding-system: utf-8-unix // End: //