From 83d870e58457a1d335a1d9b9966a6a1887cc297b Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Mon, 24 Nov 2025 03:02:43 +0100 Subject: feat! breaking changes on kernel sources. Signed-off-by: Amlal El Mahrouss --- dev/kernel/NeKit/ErrorOr.h | 62 ---------------------------------------------- 1 file changed, 62 deletions(-) delete mode 100644 dev/kernel/NeKit/ErrorOr.h (limited to 'dev/kernel/NeKit/ErrorOr.h') diff --git a/dev/kernel/NeKit/ErrorOr.h b/dev/kernel/NeKit/ErrorOr.h deleted file mode 100644 index d930fe17..00000000 --- a/dev/kernel/NeKit/ErrorOr.h +++ /dev/null @@ -1,62 +0,0 @@ -/* - * ======================================================== - * - * NeKernel - * Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under the Apache 2.0 license. - * - * ======================================================== - */ - -#pragma once - -#include -#include - -namespace Kernel { -using ErrorT = Int32; - -/// ================================================================================ -/// @brief ErrorOr class for error handling. -/// ================================================================================ -template -class ErrorOr final { - public: - explicit ErrorOr() = default; - ~ErrorOr() = default; - - public: - explicit ErrorOr(ErrorT err) : mRef((T*) RTL_ALLOCA(sizeof(T))), mId(err) {} - - explicit ErrorOr(nullPtr) {} - - explicit ErrorOr(T* Class) : mRef(Class) {} - - explicit ErrorOr(T Class) : mRef(Class) {} - - ErrorOr& operator=(const ErrorOr&) = default; - ErrorOr(const ErrorOr&) = default; - - ErrorOr& operator=(const Ref& refErr) { - mRef = refErr; - return *this; - } - - const T& Value() { return mRef.TryLeak(); } - - Ref& Leak() { return mRef; } - - ErrorT Error() { return mId; } - - /// @note DO NOT MAKE THIS EXPLICIT! IT WILL BREAK THE COMPILATION. - operator bool() { return mRef; } - - BOOL HasError() { return this->mId < 0; } - - private: - Ref mRef; - ErrorT mId{0}; -}; - -using ErrorOrAny = ErrorOr; - -} // namespace Kernel -- cgit v1.2.3