Index.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * Copyright (c) 2021, Jan de Visser <jan@de-visser.net>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <LibCore/Object.h>
  8. #include <LibSQL/Forward.h>
  9. #include <LibSQL/Meta.h>
  10. namespace SQL {
  11. class IndexNode {
  12. public:
  13. virtual ~IndexNode() = default;
  14. [[nodiscard]] u32 pointer() const { return m_pointer; }
  15. virtual void serialize(ByteBuffer&) const = 0;
  16. virtual IndexNode* as_index_node() = 0;
  17. protected:
  18. explicit IndexNode(u32 pointer)
  19. : m_pointer(pointer)
  20. {
  21. }
  22. void set_pointer(u32 pointer) { m_pointer = pointer; }
  23. private:
  24. u32 m_pointer;
  25. };
  26. class Index : public Core::Object {
  27. C_OBJECT_ABSTRACT(Index);
  28. public:
  29. ~Index() override = default;
  30. NonnullRefPtr<TupleDescriptor> descriptor() const { return m_descriptor; }
  31. [[nodiscard]] bool duplicates_allowed() const { return !m_unique; }
  32. [[nodiscard]] bool unique() const { return m_unique; }
  33. [[nodiscard]] u32 pointer() const { return m_pointer; }
  34. protected:
  35. Index(Heap& heap, NonnullRefPtr<TupleDescriptor> const&, bool unique, u32 pointer);
  36. Index(Heap& heap, NonnullRefPtr<TupleDescriptor> const&, u32 pointer);
  37. [[nodiscard]] Heap const& heap() const { return m_heap; }
  38. [[nodiscard]] Heap& heap() { return m_heap; }
  39. void set_pointer(u32 pointer) { m_pointer = pointer; }
  40. u32 new_record_pointer() { return m_heap.new_record_pointer(); }
  41. ByteBuffer read_block(u32);
  42. void add_to_write_ahead_log(IndexNode*);
  43. private:
  44. Heap& m_heap;
  45. NonnullRefPtr<TupleDescriptor> m_descriptor;
  46. bool m_unique { false };
  47. u32 m_pointer { 0 };
  48. };
  49. }