/* * ======================================================== * * CompilerKit * Copyright (C) 2024-2025 Amlal El Mahrouss, Licensed under the Apache 2.0 license. * * ======================================================== */ #pragma once #include namespace CompilerKit { /// @author Amlal El Mahrouss /// @brief Reference holder class, refers to a pointer of data in static memory. template class Ref final { public: Ref() = default; ~Ref() { if (m_Strong) { MUST_PASS(m_Class); if (m_Class) delete m_Class; m_Class = nullptr; } } NECTI_COPY_DEFAULT(Ref); public: explicit Ref(T* cls, const bool& strong = false) : m_Class(cls), m_Strong(strong) {} Ref& operator=(T ref) { *m_Class = ref; return *this; } public: T* operator->() const { return m_Class; } T& Leak() { return *m_Class; } T operator*() { return *m_Class; } bool IsStrong() const { return m_Strong; } explicit operator bool() { return *m_Class; } private: T* m_Class{nullptr}; bool m_Strong{false}; }; // @author Amlal El Mahrouss // @brief Non null Reference holder class, refers to a pointer of data in static memory. template class NonNullRef final { public: explicit NonNullRef() = delete; explicit NonNullRef(T* ref) : m_Ref(ref, true) {} Ref& operator->() { MUST_PASS(m_Ref); return m_Ref; } NonNullRef& operator=(const NonNullRef& ref) = delete; NonNullRef(const NonNullRef& ref) = default; private: Ref m_Ref{nullptr}; }; } // namespace CompilerKit