128 lines
4.1 KiB
Text
128 lines
4.1 KiB
Text
{
|
|
mode: "facet",
|
|
output_cpp_dir: "src/alloc2/facet",
|
|
output_hpp_dir: "include/xo/alloc2",
|
|
output_impl_subdir: "gc",
|
|
includes: [
|
|
// "<xo/alloc2/Allocator.hpp>",
|
|
// "<xo/alloc2/Collector.hpp>",
|
|
// "<cstdint>",
|
|
// "<cstddef>",
|
|
],
|
|
// extra includes in GCObject.hpp, if any
|
|
user_hpp_includes: [
|
|
// "\"gc/RCollector_aux.hpp\"",
|
|
],
|
|
namespace1: "xo",
|
|
namespace2: "mm",
|
|
pretext: [
|
|
"// see GCObject.hpp, also in xo-alloc2/",
|
|
"namespace xo { namespace mm { class AGCObject; }}",
|
|
],
|
|
facet: "GCObjectVisitor",
|
|
detail_subdir: "gc",
|
|
brief: "gc-aware object visitor",
|
|
using_doxygen: true,
|
|
doc: [
|
|
"Visit a gc-aware object. Visitor can traverse and update child pointers in-place."
|
|
],
|
|
types: [
|
|
// using size_type = std::size_t
|
|
// {
|
|
// name: "size_type",
|
|
// doc: ["type for an amount of memory"],
|
|
// definition: "std::size_t",
|
|
// },
|
|
// {
|
|
// name: "AAllocator",
|
|
// doc: ["fomo allocator type"],
|
|
// definition: "xo::mm::AAllocator",
|
|
// },
|
|
// {
|
|
// name: "ACollector",
|
|
// doc: ["fomo collector type"],
|
|
// definition: "xo::mm::ACollector",
|
|
// },
|
|
],
|
|
const_methods: [
|
|
// size_type shallow_size() const noexcept
|
|
// {
|
|
// name: "shallow_size",
|
|
// doc: ["memory consumption for this instance"],
|
|
// return_type: "size_type",
|
|
// args: [],
|
|
// const: true,
|
|
// noexcept: true,
|
|
// attributes: [],
|
|
// },
|
|
],
|
|
nonconst_methods: [
|
|
// void alloc_copy(void * src)
|
|
{
|
|
name: "alloc_copy",
|
|
doc: [
|
|
"allocate copy of source object at address @p src.",
|
|
"Source must be owned by this collector.",
|
|
"Increments object age"
|
|
],
|
|
return_type: "void *",
|
|
args: [
|
|
{type: "std::byte *", name: "src"},
|
|
],
|
|
const: false,
|
|
noexcept: false,
|
|
attributes: [],
|
|
},
|
|
// void visit_child(AGCObject * iface, void ** pp_data) noexcept;
|
|
{
|
|
name: "visit_child",
|
|
doc: ["visit child of a gc-aware object. May update child in-place!"],
|
|
return_type: "void",
|
|
args:[
|
|
{type: "AGCObject *", name: "iface"},
|
|
{type: "void **", name: "pp_data"},
|
|
],
|
|
const: true, // technical const. I/face not modified
|
|
noexcept: true,
|
|
attributes: [],
|
|
},
|
|
],
|
|
router_facet_explicit_content: [
|
|
"/** convenience: allocate copy for typed pointer **/",
|
|
"template <typename T>",
|
|
"void * alloc_copy_for(const T * src) noexcept {",
|
|
" return O::iface()->alloc_copy(O::data(), (std::byte *)const_cast<T *>(src));",
|
|
"}",
|
|
"",
|
|
"/** convenience: move typed pointer **/",
|
|
"template <typename T>",
|
|
"T * std_move_for(T * src) noexcept {",
|
|
" void * mem = this->alloc_copy_for(src);",
|
|
" if (mem) {",
|
|
" return new (mem) T(std::move(*src));",
|
|
" }",
|
|
" return nullptr;",
|
|
"}",
|
|
"",
|
|
"/** visit a gcobject child pointer in place.",
|
|
" Defined in RCollector_aux.hpp to avoid #include cycle",
|
|
" (for historical reasons - coul d be in RGCObject_aux.hpp?)",
|
|
" **/",
|
|
"template <typename DRepr>",
|
|
"void visit_child(xo::facet::obj<AGCObject,DRepr> * p_obj);",
|
|
"",
|
|
"/** visit typed child data pointer in place.",
|
|
" Defined in RGCObject.hpp to avoid #include cycle",
|
|
" **/",
|
|
"template <typename DRepr>",
|
|
"void visit_child(DRepr ** pp_data);",
|
|
"",
|
|
"/** visit faceted object pointer stored using some facet",
|
|
" other than AGCObject",
|
|
" **/",
|
|
"template <typename AFacet, typename DRepr>",
|
|
"requires (!std::is_same_v<AFacet, AGCObject>)",
|
|
"void visit_poly_child(obj<AFacet,DRepr> * p_pivot);",
|
|
"",
|
|
]
|
|
}
|