mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 07:32:44 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			155 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			155 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Jan de Visser <jan@de-visser.net>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/DeprecatedString.h>
 | |
| #include <AK/NonnullRefPtr.h>
 | |
| #include <AK/Result.h>
 | |
| #include <AK/Vector.h>
 | |
| #include <LibCore/Object.h>
 | |
| #include <LibSQL/Forward.h>
 | |
| #include <LibSQL/Heap.h>
 | |
| #include <LibSQL/Type.h>
 | |
| #include <LibSQL/Value.h>
 | |
| 
 | |
| namespace SQL {
 | |
| 
 | |
| /**
 | |
|  * This file declares objects describing tables, indexes, and columns.
 | |
|  * It remains to be seen if this will survive in it's current form.
 | |
|  */
 | |
| 
 | |
| class Relation : public Core::Object {
 | |
|     C_OBJECT_ABSTRACT(Relation);
 | |
| 
 | |
| public:
 | |
|     u32 hash() const;
 | |
|     Block::Index block_index() const { return m_block_index; }
 | |
|     void set_block_index(Block::Index block_index) { m_block_index = block_index; }
 | |
|     ~Relation() override = default;
 | |
|     virtual Key key() const = 0;
 | |
|     Relation const* parent_relation() const { return dynamic_cast<Relation const*>(parent()); }
 | |
| 
 | |
| protected:
 | |
|     Relation(DeprecatedString name, Block::Index block_index, Relation* parent = nullptr)
 | |
|         : Core::Object(parent)
 | |
|         , m_block_index(block_index)
 | |
|     {
 | |
|         set_name(move(name));
 | |
|     }
 | |
| 
 | |
|     explicit Relation(DeprecatedString name, Relation* parent = nullptr)
 | |
|         : Core::Object(parent)
 | |
|         , m_block_index(0)
 | |
|     {
 | |
|         set_name(move(name));
 | |
|     }
 | |
| 
 | |
| private:
 | |
|     Block::Index m_block_index { 0 };
 | |
| };
 | |
| 
 | |
| class SchemaDef : public Relation {
 | |
|     C_OBJECT(SchemaDef);
 | |
| 
 | |
| public:
 | |
|     Key key() const override;
 | |
|     static NonnullRefPtr<IndexDef> index_def();
 | |
|     static Key make_key();
 | |
| 
 | |
| private:
 | |
|     explicit SchemaDef(DeprecatedString);
 | |
|     explicit SchemaDef(Key const&);
 | |
| };
 | |
| 
 | |
| class ColumnDef : public Relation {
 | |
|     C_OBJECT(ColumnDef);
 | |
| 
 | |
| public:
 | |
|     Key key() const override;
 | |
|     SQLType type() const { return m_type; }
 | |
|     size_t column_number() const { return m_index; }
 | |
|     void set_not_null(bool can_not_be_null) { m_not_null = can_not_be_null; }
 | |
|     bool not_null() const { return m_not_null; }
 | |
|     void set_default_value(Value const& default_value);
 | |
|     Value const& default_value() const { return m_default; }
 | |
| 
 | |
|     static NonnullRefPtr<IndexDef> index_def();
 | |
|     static Key make_key(TableDef const&);
 | |
| 
 | |
| protected:
 | |
|     ColumnDef(Relation*, size_t, DeprecatedString, SQLType);
 | |
| 
 | |
| private:
 | |
|     size_t m_index;
 | |
|     SQLType m_type { SQLType::Text };
 | |
|     bool m_not_null { false };
 | |
|     Value m_default;
 | |
| };
 | |
| 
 | |
| class KeyPartDef : public ColumnDef {
 | |
|     C_OBJECT(KeyPartDef);
 | |
| 
 | |
| public:
 | |
|     Order sort_order() const { return m_sort_order; }
 | |
| 
 | |
| private:
 | |
|     KeyPartDef(IndexDef*, DeprecatedString, SQLType, Order = Order::Ascending);
 | |
| 
 | |
|     Order m_sort_order { Order::Ascending };
 | |
| };
 | |
| 
 | |
| class IndexDef : public Relation {
 | |
|     C_OBJECT(IndexDef);
 | |
| 
 | |
| public:
 | |
|     ~IndexDef() override = default;
 | |
| 
 | |
|     Vector<NonnullRefPtr<KeyPartDef>> const& key_definition() const { return m_key_definition; }
 | |
|     bool unique() const { return m_unique; }
 | |
|     [[nodiscard]] size_t size() const { return m_key_definition.size(); }
 | |
|     void append_column(DeprecatedString, SQLType, Order = Order::Ascending);
 | |
|     Key key() const override;
 | |
|     [[nodiscard]] NonnullRefPtr<TupleDescriptor> to_tuple_descriptor() const;
 | |
|     static NonnullRefPtr<IndexDef> index_def();
 | |
|     static Key make_key(TableDef const& table_def);
 | |
| 
 | |
| private:
 | |
|     IndexDef(TableDef*, DeprecatedString, bool unique = true, u32 pointer = 0);
 | |
|     explicit IndexDef(DeprecatedString, bool unique = true, u32 pointer = 0);
 | |
| 
 | |
|     Vector<NonnullRefPtr<KeyPartDef>> m_key_definition;
 | |
|     bool m_unique { false };
 | |
| 
 | |
|     friend TableDef;
 | |
| };
 | |
| 
 | |
| class TableDef : public Relation {
 | |
|     C_OBJECT(TableDef);
 | |
| 
 | |
| public:
 | |
|     Key key() const override;
 | |
|     void append_column(DeprecatedString, SQLType);
 | |
|     void append_column(Key const&);
 | |
|     size_t num_columns() { return m_columns.size(); }
 | |
|     size_t num_indexes() { return m_indexes.size(); }
 | |
|     Vector<NonnullRefPtr<ColumnDef>> const& columns() const { return m_columns; }
 | |
|     Vector<NonnullRefPtr<IndexDef>> const& indexes() const { return m_indexes; }
 | |
|     [[nodiscard]] NonnullRefPtr<TupleDescriptor> to_tuple_descriptor() const;
 | |
| 
 | |
|     static NonnullRefPtr<IndexDef> index_def();
 | |
|     static Key make_key(SchemaDef const& schema_def);
 | |
|     static Key make_key(Key const& schema_key);
 | |
| 
 | |
| private:
 | |
|     explicit TableDef(SchemaDef*, DeprecatedString);
 | |
| 
 | |
|     Vector<NonnullRefPtr<ColumnDef>> m_columns;
 | |
|     Vector<NonnullRefPtr<IndexDef>> m_indexes;
 | |
| };
 | |
| 
 | |
| }
 | 
