From 5339d016c07bf717ee388f4feb73544087324af0 Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Sat, 6 Jan 2024 09:14:11 +0100 Subject: git: port from mercurial repo. Signed-off-by: Amlal El Mahrouss --- KernelKit/SharedObjectCore.hxx | 57 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 KernelKit/SharedObjectCore.hxx (limited to 'KernelKit/SharedObjectCore.hxx') diff --git a/KernelKit/SharedObjectCore.hxx b/KernelKit/SharedObjectCore.hxx new file mode 100644 index 00000000..51637192 --- /dev/null +++ b/KernelKit/SharedObjectCore.hxx @@ -0,0 +1,57 @@ +/* + * ======================================================== + * + * hCore + * Copyright Mahrouss Logic, all rights reserved. + * + * ======================================================== + */ + +#ifndef __SUPPORTKIT_SHARED_OBJECT_CORE_HXX__ +#define __SUPPORTKIT_SHARED_OBJECT_CORE_HXX__ + +#include +#include + +namespace hCore +{ + class SharedObject final + { + public: + struct SharedObjectTraits final + { + VoidPtr fImageObject; + VoidPtr fImageEntrypointOffset; + }; + + public: + explicit SharedObject() = default; + ~SharedObject() = default; + + public: + HCORE_COPY_DEFAULT(SharedObject); + + private: + SharedObjectTraits* fMounted{ nullptr }; + + public: + SharedObjectTraits** GetAddressOf() { return &fMounted; } + SharedObjectTraits* Get() { return fMounted; } + + public: + void Mount(SharedObjectTraits* to_mount) { fMounted = to_mount; } + void Unmount() { if (fMounted) fMounted = nullptr; }; + + template + SymbolType Load(const char* symbol_name); + + }; + + inline void hcore_pure_call(void) + { + // virtual placeholder. + return; + } +} + +#endif /* ifndef __SUPPORTKIT_SHARED_OBJECT_CORE_HXX__ */ -- cgit v1.2.3