summaryrefslogtreecommitdiffhomepage
path: root/KernelKit/SharedObjectCore.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'KernelKit/SharedObjectCore.hxx')
-rw-r--r--KernelKit/SharedObjectCore.hxx57
1 files changed, 57 insertions, 0 deletions
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 <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 __SUPPORTKIT_SHARED_OBJECT_CORE_HXX__ */