Meta.cpp 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. /*
  2. * Copyright (c) 2021, Jan de Visser <jan@de-visser.net>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibSQL/Key.h>
  7. #include <LibSQL/Meta.h>
  8. #include <LibSQL/Type.h>
  9. namespace SQL {
  10. u32 Relation::hash() const
  11. {
  12. return key().hash();
  13. }
  14. ErrorOr<NonnullRefPtr<SchemaDef>> SchemaDef::create(ByteString name)
  15. {
  16. return adopt_nonnull_ref_or_enomem(new (nothrow) SchemaDef(move(name)));
  17. }
  18. ErrorOr<NonnullRefPtr<SchemaDef>> SchemaDef::create(Key const& key)
  19. {
  20. return create(key["schema_name"].to_byte_string());
  21. }
  22. SchemaDef::SchemaDef(ByteString name)
  23. : Relation(move(name))
  24. {
  25. }
  26. Key SchemaDef::key() const
  27. {
  28. auto key = Key(index_def()->to_tuple_descriptor());
  29. key["schema_name"] = name();
  30. key.set_block_index(block_index());
  31. return key;
  32. }
  33. Key SchemaDef::make_key()
  34. {
  35. return Key(index_def());
  36. }
  37. NonnullRefPtr<IndexDef> SchemaDef::index_def()
  38. {
  39. NonnullRefPtr<IndexDef> s_index_def = IndexDef::create("$schema", true, 0).release_value_but_fixme_should_propagate_errors();
  40. if (!s_index_def->size()) {
  41. s_index_def->append_column("schema_name", SQLType::Text, Order::Ascending);
  42. }
  43. return s_index_def;
  44. }
  45. ErrorOr<NonnullRefPtr<ColumnDef>> ColumnDef::create(Relation* parent, size_t column_number, ByteString name, SQLType sql_type)
  46. {
  47. return adopt_nonnull_ref_or_enomem(new (nothrow) ColumnDef(parent, column_number, move(name), sql_type));
  48. }
  49. ColumnDef::ColumnDef(Relation* parent, size_t column_number, ByteString name, SQLType sql_type)
  50. : Relation(move(name), parent)
  51. , m_index(column_number)
  52. , m_type(sql_type)
  53. , m_default(Value(sql_type))
  54. {
  55. }
  56. Key ColumnDef::key() const
  57. {
  58. auto key = Key(index_def());
  59. key["table_hash"] = parent()->hash();
  60. key["column_number"] = column_number();
  61. key["column_name"] = name();
  62. key["column_type"] = to_underlying(type());
  63. return key;
  64. }
  65. void ColumnDef::set_default_value(Value const& default_value)
  66. {
  67. VERIFY(default_value.type() == type());
  68. m_default = default_value;
  69. }
  70. Key ColumnDef::make_key(TableDef const& table_def)
  71. {
  72. Key key(index_def());
  73. key["table_hash"] = table_def.key().hash();
  74. return key;
  75. }
  76. NonnullRefPtr<IndexDef> ColumnDef::index_def()
  77. {
  78. NonnullRefPtr<IndexDef> s_index_def = IndexDef::create("$column", true, 0).release_value_but_fixme_should_propagate_errors();
  79. if (!s_index_def->size()) {
  80. s_index_def->append_column("table_hash", SQLType::Integer, Order::Ascending);
  81. s_index_def->append_column("column_number", SQLType::Integer, Order::Ascending);
  82. s_index_def->append_column("column_name", SQLType::Text, Order::Ascending);
  83. s_index_def->append_column("column_type", SQLType::Integer, Order::Ascending);
  84. }
  85. return s_index_def;
  86. }
  87. ErrorOr<NonnullRefPtr<KeyPartDef>> KeyPartDef::create(IndexDef* index, ByteString name, SQLType sql_type, Order sort_order)
  88. {
  89. return adopt_nonnull_ref_or_enomem(new (nothrow) KeyPartDef(index, move(name), sql_type, sort_order));
  90. }
  91. KeyPartDef::KeyPartDef(IndexDef* index, ByteString name, SQLType sql_type, Order sort_order)
  92. : ColumnDef(index, index->size(), move(name), sql_type)
  93. , m_sort_order(sort_order)
  94. {
  95. }
  96. ErrorOr<NonnullRefPtr<IndexDef>> IndexDef::create(TableDef* table, ByteString name, bool unique, u32 pointer)
  97. {
  98. return adopt_nonnull_ref_or_enomem(new (nothrow) IndexDef(table, move(name), unique, pointer));
  99. }
  100. ErrorOr<NonnullRefPtr<IndexDef>> IndexDef::create(ByteString name, bool unique, u32 pointer)
  101. {
  102. return create(nullptr, move(name), unique, pointer);
  103. }
  104. IndexDef::IndexDef(TableDef* table, ByteString name, bool unique, u32 pointer)
  105. : Relation(move(name), pointer, table)
  106. , m_key_definition()
  107. , m_unique(unique)
  108. {
  109. }
  110. void IndexDef::append_column(ByteString name, SQLType sql_type, Order sort_order)
  111. {
  112. auto part = KeyPartDef::create(this, move(name), sql_type, sort_order).release_value_but_fixme_should_propagate_errors();
  113. m_key_definition.append(part);
  114. }
  115. NonnullRefPtr<TupleDescriptor> IndexDef::to_tuple_descriptor() const
  116. {
  117. NonnullRefPtr<TupleDescriptor> ret = adopt_ref(*new TupleDescriptor);
  118. for (auto& part : m_key_definition) {
  119. ret->append({ "", "", part->name(), part->type(), part->sort_order() });
  120. }
  121. return ret;
  122. }
  123. Key IndexDef::key() const
  124. {
  125. auto key = Key(index_def()->to_tuple_descriptor());
  126. key["table_hash"] = parent()->key().hash();
  127. key["index_name"] = name();
  128. key["unique"] = unique() ? 1 : 0;
  129. return key;
  130. }
  131. Key IndexDef::make_key(TableDef const& table_def)
  132. {
  133. Key key(index_def());
  134. key["table_hash"] = table_def.key().hash();
  135. return key;
  136. }
  137. NonnullRefPtr<IndexDef> IndexDef::index_def()
  138. {
  139. NonnullRefPtr<IndexDef> s_index_def = IndexDef::create("$index", true, 0).release_value_but_fixme_should_propagate_errors();
  140. if (!s_index_def->size()) {
  141. s_index_def->append_column("table_hash", SQLType::Integer, Order::Ascending);
  142. s_index_def->append_column("index_name", SQLType::Text, Order::Ascending);
  143. s_index_def->append_column("unique", SQLType::Integer, Order::Ascending);
  144. }
  145. return s_index_def;
  146. }
  147. ErrorOr<NonnullRefPtr<TableDef>> TableDef::create(SchemaDef* schema, ByteString name)
  148. {
  149. return adopt_nonnull_ref_or_enomem(new (nothrow) TableDef(schema, move(name)));
  150. }
  151. TableDef::TableDef(SchemaDef* schema, ByteString name)
  152. : Relation(move(name), schema)
  153. , m_columns()
  154. , m_indexes()
  155. {
  156. }
  157. NonnullRefPtr<TupleDescriptor> TableDef::to_tuple_descriptor() const
  158. {
  159. NonnullRefPtr<TupleDescriptor> ret = adopt_ref(*new TupleDescriptor);
  160. for (auto& part : m_columns) {
  161. ret->append({ parent()->name(), name(), part->name(), part->type(), Order::Ascending });
  162. }
  163. return ret;
  164. }
  165. Key TableDef::key() const
  166. {
  167. auto key = Key(index_def()->to_tuple_descriptor());
  168. key["schema_hash"] = parent()->key().hash();
  169. key["table_name"] = name();
  170. key.set_block_index(block_index());
  171. return key;
  172. }
  173. void TableDef::append_column(ByteString name, SQLType sql_type)
  174. {
  175. auto column = ColumnDef::create(this, num_columns(), move(name), sql_type).release_value_but_fixme_should_propagate_errors();
  176. m_columns.append(column);
  177. }
  178. void TableDef::append_column(Key const& column)
  179. {
  180. auto column_type = column["column_type"].to_int<UnderlyingType<SQLType>>();
  181. VERIFY(column_type.has_value());
  182. append_column(column["column_name"].to_byte_string(), static_cast<SQLType>(*column_type));
  183. }
  184. Key TableDef::make_key(SchemaDef const& schema_def)
  185. {
  186. return TableDef::make_key(schema_def.key());
  187. }
  188. Key TableDef::make_key(Key const& schema_key)
  189. {
  190. Key key(index_def());
  191. key["schema_hash"] = schema_key.hash();
  192. return key;
  193. }
  194. NonnullRefPtr<IndexDef> TableDef::index_def()
  195. {
  196. NonnullRefPtr<IndexDef> s_index_def = IndexDef::create("$table", true, 0).release_value_but_fixme_should_propagate_errors();
  197. if (!s_index_def->size()) {
  198. s_index_def->append_column("schema_hash", SQLType::Integer, Order::Ascending);
  199. s_index_def->append_column("table_name", SQLType::Text, Order::Ascending);
  200. }
  201. return s_index_def;
  202. }
  203. }