summaryrefslogtreecommitdiffhomepage
path: root/src/kernel/CFKit/Property.h
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal@nekernel.org>2025-11-23 21:06:27 -0500
committerGitHub <noreply@github.com>2025-11-23 21:06:27 -0500
commit23040fad647634c08697451fc22ee2ca999629c8 (patch)
tree72888f88c7728c82f3f6df1f4f70591de15eab36 /src/kernel/CFKit/Property.h
parente5cc7351f0577b54c528fb827a7c7e6306c3e843 (diff)
parent83d870e58457a1d335a1d9b9966a6a1887cc297b (diff)
Merge pull request #81 from nekernel-org/dev
feat! breaking changes on kernel sources.
Diffstat (limited to 'src/kernel/CFKit/Property.h')
-rw-r--r--src/kernel/CFKit/Property.h51
1 files changed, 51 insertions, 0 deletions
diff --git a/src/kernel/CFKit/Property.h b/src/kernel/CFKit/Property.h
new file mode 100644
index 00000000..cfb8a599
--- /dev/null
+++ b/src/kernel/CFKit/Property.h
@@ -0,0 +1,51 @@
+/* ========================================
+
+ Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under the Apache 2.0 license.
+
+======================================== */
+
+#ifndef CFKIT_PROPS_H
+#define CFKIT_PROPS_H
+
+#include <CFKit/GUIDWrapper.h>
+#include <NeKit/Array.h>
+#include <NeKit/Defines.h>
+#include <NeKit/Function.h>
+#include <NeKit/KString.h>
+
+#define kMaxPropLen (256U)
+
+namespace Kernel::CF {
+/// @brief handle to anything (number, ptr, string...)
+using PropertyId = UIntPtr;
+
+/// @brief Kernel property class.
+/// @example /prop/smp_max or /prop/kern_ver
+class Property {
+ public:
+ Property();
+ virtual ~Property();
+
+ public:
+ Property& operator=(const Property&) = default;
+ Property(const Property&) = default;
+
+ BOOL StringEquals(KBasicString<>& name);
+ PropertyId& GetValue();
+ KBasicString<>& GetKey();
+
+ private:
+ KString fName{kMaxPropLen};
+ PropertyId fValue{0UL};
+ Ref<XRN::GUID> fGUID{};
+};
+
+template <SizeT N>
+using PropertyArray = Array<Property, N>;
+} // namespace Kernel::CF
+
+namespace Kernel {
+using namespace Kernel::CF;
+}
+
+#endif // !CFKIT_PROPS_H