Shamrock 2025.10.0
Astrophysical Code
Loading...
Searching...
No Matches
PatchDataLayerEdge.hpp
Go to the documentation of this file.
1// -------------------------------------------------------//
2//
3// SHAMROCK code for hydrodynamics
4// Copyright (c) 2021-2026 Timothée David--Cléris <tim.shamrock@proton.me>
5// SPDX-License-Identifier: CeCILL Free Software License Agreement v2.1
6// Shamrock is licensed under the CeCILL 2.1 License, see LICENSE for more information
7//
8// -------------------------------------------------------//
9
10#pragma once
11
20#include "shambase/memory.hpp"
25#include <memory>
26
27namespace shamrock::solvergraph {
28
30
32
33 std::shared_ptr<patch::PatchDataLayerLayout> layout;
36
37 public:
38 using IPatchDataLayerRefs::IPatchDataLayerRefs;
39
40 inline PatchDataLayerEdge(
41 const std::string &name,
42 const std::string &label,
43 std::shared_ptr<patch::PatchDataLayerLayout> layout)
44 : IPatchDataLayerRefs(name, label), layout(layout) {}
45
46 inline void set_patchdatas(shambase::DistributedData<patch::PatchDataLayer> &&src) {
47 patchdatas = std::move(src);
48 patchdatas_refs = patchdatas.map<PatchDataLayerRef>(
49 [](u64 id, patch::PatchDataLayer &layer) -> PatchDataLayerRef {
50 return std::ref(layer);
51 });
52 }
53
54 inline shambase::DistributedData<patch::PatchDataLayer> extract_patchdatas() {
55 auto tmp = std::move(patchdatas);
56 set_patchdatas({});
57 return tmp;
58 }
59
60 inline const patch::PatchDataLayerLayout &pdl() const {
61 return shambase::get_check_ref(layout);
62 }
63
64 inline std::shared_ptr<patch::PatchDataLayerLayout> &get_layout_ptr() { return layout; }
65
66 inline virtual patch::PatchDataLayer &get(u64 id_patch) override {
67 return patchdatas.get(id_patch);
68 }
69
70 inline virtual const patch::PatchDataLayer &get(u64 id_patch) const override {
71 return patchdatas.get(id_patch);
72 }
73
74 inline virtual shambase::DistributedData<PatchDataLayerRef> &get_refs() override {
75 return patchdatas_refs;
76 }
77
78 inline virtual const shambase::DistributedData<PatchDataLayerRef> &get_const_refs()
79 const override {
80 return patchdatas_refs;
81 }
82
83 inline virtual void free_alloc() override {
84 layout = {};
85 patchdatas = {};
86 patchdatas_refs = {};
87 }
88 };
89} // namespace shamrock::solvergraph
Defines the PatchDataLayerRefs class for managing distributed references to patch data layers.
std::uint64_t u64
64 bit unsigned integer
DistributedData< Tmap > map(std::function< Tmap(u64, T &)> map_func)
Apply a function to all objects in the collection and return a new collection containing the results.
T & get(u64 id)
Returns a reference to an object in the collection.
PatchDataLayer container class, the layout is described in patchdata_layout.
virtual void free_alloc() override
Free allocated memory.
T & get_check_ref(const std::unique_ptr< T > &ptr, SourceLocation loc=SourceLocation())
Takes a std::unique_ptr and returns a reference to the object it holds. It throws a std::runtime_erro...
Definition memory.hpp:110