summaryrefslogtreecommitdiffhomepage
path: root/Private/KernelKit/SharedObjectCore.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'Private/KernelKit/SharedObjectCore.hxx')
-rw-r--r--Private/KernelKit/SharedObjectCore.hxx57
1 files changed, 57 insertions, 0 deletions
diff --git a/Private/KernelKit/SharedObjectCore.hxx b/Private/KernelKit/SharedObjectCore.hxx
new file mode 100644
index 00000000..94b0ead2
--- /dev/null
+++ b/Private/KernelKit/SharedObjectCore.hxx
@@ -0,0 +1,57 @@
+/*
+ * ========================================================
+ *
+ * hCore
+ * Copyright 2024 Mahrouss Logic, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#ifndef __KERNELKIT_SHARED_OBJECT_CORE_HXX__
+#define __KERNELKIT_SHARED_OBJECT_CORE_HXX__
+
+#include <NewKit/Defines.hpp>
+#include <KernelKit/Loader.hpp>
+
+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 <typename SymbolType>
+ SymbolType Load(const char* symbol_name);
+
+ };
+
+ inline void hcore_pure_call(void)
+ {
+ // virtual placeholder.
+ return;
+ }
+}
+
+#endif /* ifndef __KERNELKIT_SHARED_OBJECT_CORE_HXX__ */