AST.h 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052
  1. /*
  2. * Copyright (c) 2021, Tim Flynn <trflynn89@pm.me>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/NonnullRefPtr.h>
  8. #include <AK/NonnullRefPtrVector.h>
  9. #include <AK/RefCounted.h>
  10. #include <AK/RefPtr.h>
  11. #include <AK/String.h>
  12. #include <LibSQL/AST/Token.h>
  13. #include <LibSQL/Forward.h>
  14. #include <LibSQL/SQLResult.h>
  15. #include <LibSQL/Type.h>
  16. namespace SQL::AST {
  17. template<class T, class... Args>
  18. static inline NonnullRefPtr<T>
  19. create_ast_node(Args&&... args)
  20. {
  21. return adopt_ref(*new T(forward<Args>(args)...));
  22. }
  23. class ASTNode : public RefCounted<ASTNode> {
  24. public:
  25. virtual ~ASTNode() { }
  26. protected:
  27. ASTNode() = default;
  28. };
  29. //==================================================================================================
  30. // Language types
  31. //==================================================================================================
  32. class SignedNumber final : public ASTNode {
  33. public:
  34. explicit SignedNumber(double value)
  35. : m_value(value)
  36. {
  37. }
  38. double value() const { return m_value; }
  39. private:
  40. double m_value;
  41. };
  42. class TypeName : public ASTNode {
  43. public:
  44. TypeName(String name, NonnullRefPtrVector<SignedNumber> signed_numbers)
  45. : m_name(move(name))
  46. , m_signed_numbers(move(signed_numbers))
  47. {
  48. VERIFY(m_signed_numbers.size() <= 2);
  49. }
  50. const String& name() const { return m_name; }
  51. const NonnullRefPtrVector<SignedNumber>& signed_numbers() const { return m_signed_numbers; }
  52. private:
  53. String m_name;
  54. NonnullRefPtrVector<SignedNumber> m_signed_numbers;
  55. };
  56. class ColumnDefinition : public ASTNode {
  57. public:
  58. ColumnDefinition(String name, NonnullRefPtr<TypeName> type_name)
  59. : m_name(move(name))
  60. , m_type_name(move(type_name))
  61. {
  62. }
  63. const String& name() const { return m_name; }
  64. const NonnullRefPtr<TypeName>& type_name() const { return m_type_name; }
  65. private:
  66. String m_name;
  67. NonnullRefPtr<TypeName> m_type_name;
  68. };
  69. class CommonTableExpression : public ASTNode {
  70. public:
  71. CommonTableExpression(String table_name, Vector<String> column_names, NonnullRefPtr<Select> select_statement)
  72. : m_table_name(move(table_name))
  73. , m_column_names(move(column_names))
  74. , m_select_statement(move(select_statement))
  75. {
  76. }
  77. const String& table_name() const { return m_table_name; }
  78. const Vector<String>& column_names() const { return m_column_names; }
  79. const NonnullRefPtr<Select>& select_statement() const { return m_select_statement; }
  80. private:
  81. String m_table_name;
  82. Vector<String> m_column_names;
  83. NonnullRefPtr<Select> m_select_statement;
  84. };
  85. class CommonTableExpressionList : public ASTNode {
  86. public:
  87. CommonTableExpressionList(bool recursive, NonnullRefPtrVector<CommonTableExpression> common_table_expressions)
  88. : m_recursive(recursive)
  89. , m_common_table_expressions(move(common_table_expressions))
  90. {
  91. VERIFY(!m_common_table_expressions.is_empty());
  92. }
  93. bool recursive() const { return m_recursive; }
  94. const NonnullRefPtrVector<CommonTableExpression>& common_table_expressions() const { return m_common_table_expressions; }
  95. private:
  96. bool m_recursive;
  97. NonnullRefPtrVector<CommonTableExpression> m_common_table_expressions;
  98. };
  99. class QualifiedTableName : public ASTNode {
  100. public:
  101. QualifiedTableName(String schema_name, String table_name, String alias)
  102. : m_schema_name(move(schema_name))
  103. , m_table_name(move(table_name))
  104. , m_alias(move(alias))
  105. {
  106. }
  107. const String& schema_name() const { return m_schema_name; }
  108. const String& table_name() const { return m_table_name; }
  109. const String& alias() const { return m_alias; }
  110. private:
  111. String m_schema_name;
  112. String m_table_name;
  113. String m_alias;
  114. };
  115. class ReturningClause : public ASTNode {
  116. public:
  117. struct ColumnClause {
  118. NonnullRefPtr<Expression> expression;
  119. String column_alias;
  120. };
  121. ReturningClause() = default;
  122. explicit ReturningClause(Vector<ColumnClause> columns)
  123. : m_columns(move(columns))
  124. {
  125. }
  126. bool return_all_columns() const { return m_columns.is_empty(); };
  127. const Vector<ColumnClause>& columns() const { return m_columns; }
  128. private:
  129. Vector<ColumnClause> m_columns;
  130. };
  131. enum class ResultType {
  132. All,
  133. Table,
  134. Expression,
  135. };
  136. class ResultColumn : public ASTNode {
  137. public:
  138. ResultColumn() = default;
  139. explicit ResultColumn(String table_name)
  140. : m_type(ResultType::Table)
  141. , m_table_name(move(table_name))
  142. {
  143. }
  144. ResultColumn(NonnullRefPtr<Expression> expression, String column_alias)
  145. : m_type(ResultType::Expression)
  146. , m_expression(move(expression))
  147. , m_column_alias(move(column_alias))
  148. {
  149. }
  150. ResultType type() const { return m_type; }
  151. bool select_from_table() const { return !m_table_name.is_null(); }
  152. const String& table_name() const { return m_table_name; }
  153. bool select_from_expression() const { return !m_expression.is_null(); }
  154. const RefPtr<Expression>& expression() const { return m_expression; }
  155. const String& column_alias() const { return m_column_alias; }
  156. private:
  157. ResultType m_type { ResultType::All };
  158. String m_table_name {};
  159. RefPtr<Expression> m_expression {};
  160. String m_column_alias {};
  161. };
  162. class GroupByClause : public ASTNode {
  163. public:
  164. GroupByClause(NonnullRefPtrVector<Expression> group_by_list, RefPtr<Expression> having_clause)
  165. : m_group_by_list(move(group_by_list))
  166. , m_having_clause(move(having_clause))
  167. {
  168. VERIFY(!m_group_by_list.is_empty());
  169. }
  170. const NonnullRefPtrVector<Expression>& group_by_list() const { return m_group_by_list; }
  171. const RefPtr<Expression>& having_clause() const { return m_having_clause; }
  172. private:
  173. NonnullRefPtrVector<Expression> m_group_by_list;
  174. RefPtr<Expression> m_having_clause;
  175. };
  176. class TableOrSubquery : public ASTNode {
  177. public:
  178. TableOrSubquery() = default;
  179. TableOrSubquery(String schema_name, String table_name, String table_alias)
  180. : m_is_table(true)
  181. , m_schema_name(move(schema_name))
  182. , m_table_name(move(table_name))
  183. , m_table_alias(move(table_alias))
  184. {
  185. }
  186. explicit TableOrSubquery(NonnullRefPtrVector<TableOrSubquery> subqueries)
  187. : m_is_subquery(!subqueries.is_empty())
  188. , m_subqueries(move(subqueries))
  189. {
  190. }
  191. bool is_table() const { return m_is_table; }
  192. const String& schema_name() const { return m_schema_name; }
  193. const String& table_name() const { return m_table_name; }
  194. const String& table_alias() const { return m_table_alias; }
  195. bool is_subquery() const { return m_is_subquery; }
  196. const NonnullRefPtrVector<TableOrSubquery>& subqueries() const { return m_subqueries; }
  197. private:
  198. bool m_is_table { false };
  199. String m_schema_name {};
  200. String m_table_name {};
  201. String m_table_alias {};
  202. bool m_is_subquery { false };
  203. NonnullRefPtrVector<TableOrSubquery> m_subqueries {};
  204. };
  205. class OrderingTerm : public ASTNode {
  206. public:
  207. OrderingTerm(NonnullRefPtr<Expression> expression, String collation_name, Order order, Nulls nulls)
  208. : m_expression(move(expression))
  209. , m_collation_name(move(collation_name))
  210. , m_order(order)
  211. , m_nulls(nulls)
  212. {
  213. }
  214. const NonnullRefPtr<Expression>& expression() const { return m_expression; }
  215. const String& collation_name() const { return m_collation_name; }
  216. Order order() const { return m_order; }
  217. Nulls nulls() const { return m_nulls; }
  218. private:
  219. NonnullRefPtr<Expression> m_expression;
  220. String m_collation_name;
  221. Order m_order;
  222. Nulls m_nulls;
  223. };
  224. class LimitClause : public ASTNode {
  225. public:
  226. LimitClause(NonnullRefPtr<Expression> limit_expression, RefPtr<Expression> offset_expression)
  227. : m_limit_expression(move(limit_expression))
  228. , m_offset_expression(move(offset_expression))
  229. {
  230. }
  231. const NonnullRefPtr<Expression>& limit_expression() const { return m_limit_expression; }
  232. const RefPtr<Expression>& offset_expression() const { return m_offset_expression; }
  233. private:
  234. NonnullRefPtr<Expression> m_limit_expression;
  235. RefPtr<Expression> m_offset_expression;
  236. };
  237. //==================================================================================================
  238. // Expressions
  239. //==================================================================================================
  240. struct ExecutionContext {
  241. NonnullRefPtr<Database> database;
  242. RefPtr<SQLResult> result { nullptr };
  243. class Statement const* statement;
  244. Tuple* current_row { nullptr };
  245. };
  246. class Expression : public ASTNode {
  247. public:
  248. virtual Value evaluate(ExecutionContext&) const;
  249. };
  250. class ErrorExpression final : public Expression {
  251. };
  252. class NumericLiteral : public Expression {
  253. public:
  254. explicit NumericLiteral(double value)
  255. : m_value(value)
  256. {
  257. }
  258. double value() const { return m_value; }
  259. virtual Value evaluate(ExecutionContext&) const override;
  260. private:
  261. double m_value;
  262. };
  263. class StringLiteral : public Expression {
  264. public:
  265. explicit StringLiteral(String value)
  266. : m_value(move(value))
  267. {
  268. }
  269. const String& value() const { return m_value; }
  270. virtual Value evaluate(ExecutionContext&) const override;
  271. private:
  272. String m_value;
  273. };
  274. class BlobLiteral : public Expression {
  275. public:
  276. explicit BlobLiteral(String value)
  277. : m_value(move(value))
  278. {
  279. }
  280. const String& value() const { return m_value; }
  281. private:
  282. String m_value;
  283. };
  284. class NullLiteral : public Expression {
  285. public:
  286. virtual Value evaluate(ExecutionContext&) const override;
  287. };
  288. class NestedExpression : public Expression {
  289. public:
  290. const NonnullRefPtr<Expression>& expression() const { return m_expression; }
  291. virtual Value evaluate(ExecutionContext&) const override;
  292. protected:
  293. explicit NestedExpression(NonnullRefPtr<Expression> expression)
  294. : m_expression(move(expression))
  295. {
  296. }
  297. private:
  298. NonnullRefPtr<Expression> m_expression;
  299. };
  300. class NestedDoubleExpression : public Expression {
  301. public:
  302. const NonnullRefPtr<Expression>& lhs() const { return m_lhs; }
  303. const NonnullRefPtr<Expression>& rhs() const { return m_rhs; }
  304. protected:
  305. NestedDoubleExpression(NonnullRefPtr<Expression> lhs, NonnullRefPtr<Expression> rhs)
  306. : m_lhs(move(lhs))
  307. , m_rhs(move(rhs))
  308. {
  309. }
  310. private:
  311. NonnullRefPtr<Expression> m_lhs;
  312. NonnullRefPtr<Expression> m_rhs;
  313. };
  314. class InvertibleNestedExpression : public NestedExpression {
  315. public:
  316. bool invert_expression() const { return m_invert_expression; }
  317. protected:
  318. InvertibleNestedExpression(NonnullRefPtr<Expression> expression, bool invert_expression)
  319. : NestedExpression(move(expression))
  320. , m_invert_expression(invert_expression)
  321. {
  322. }
  323. private:
  324. bool m_invert_expression;
  325. };
  326. class InvertibleNestedDoubleExpression : public NestedDoubleExpression {
  327. public:
  328. bool invert_expression() const { return m_invert_expression; }
  329. protected:
  330. InvertibleNestedDoubleExpression(NonnullRefPtr<Expression> lhs, NonnullRefPtr<Expression> rhs, bool invert_expression)
  331. : NestedDoubleExpression(move(lhs), move(rhs))
  332. , m_invert_expression(invert_expression)
  333. {
  334. }
  335. private:
  336. bool m_invert_expression;
  337. };
  338. class ColumnNameExpression : public Expression {
  339. public:
  340. ColumnNameExpression(String schema_name, String table_name, String column_name)
  341. : m_schema_name(move(schema_name))
  342. , m_table_name(move(table_name))
  343. , m_column_name(move(column_name))
  344. {
  345. }
  346. const String& schema_name() const { return m_schema_name; }
  347. const String& table_name() const { return m_table_name; }
  348. const String& column_name() const { return m_column_name; }
  349. virtual Value evaluate(ExecutionContext&) const override;
  350. private:
  351. String m_schema_name;
  352. String m_table_name;
  353. String m_column_name;
  354. };
  355. #define __enum_UnaryOperator(S) \
  356. S(Minus, "-") \
  357. S(Plus, "+") \
  358. S(BitwiseNot, "~") \
  359. S(Not, "NOT")
  360. enum class UnaryOperator {
  361. #undef __UnaryOperator
  362. #define __UnaryOperator(code, name) code,
  363. __enum_UnaryOperator(__UnaryOperator)
  364. #undef __UnaryOperator
  365. };
  366. constexpr char const* UnaryOperator_name(UnaryOperator op)
  367. {
  368. switch (op) {
  369. #undef __UnaryOperator
  370. #define __UnaryOperator(code, name) \
  371. case UnaryOperator::code: \
  372. return name;
  373. __enum_UnaryOperator(__UnaryOperator)
  374. #undef __UnaryOperator
  375. default : VERIFY_NOT_REACHED();
  376. }
  377. }
  378. class UnaryOperatorExpression : public NestedExpression {
  379. public:
  380. UnaryOperatorExpression(UnaryOperator type, NonnullRefPtr<Expression> expression)
  381. : NestedExpression(move(expression))
  382. , m_type(type)
  383. {
  384. }
  385. UnaryOperator type() const { return m_type; }
  386. virtual Value evaluate(ExecutionContext&) const override;
  387. private:
  388. UnaryOperator m_type;
  389. };
  390. // Note: These are in order of highest-to-lowest operator precedence.
  391. #define __enum_BinaryOperator(S) \
  392. S(Concatenate, "||") \
  393. S(Multiplication, "*") \
  394. S(Division, "/") \
  395. S(Modulo, "%") \
  396. S(Plus, "+") \
  397. S(Minus, "-") \
  398. S(ShiftLeft, "<<") \
  399. S(ShiftRight, ">>") \
  400. S(BitwiseAnd, "&") \
  401. S(BitwiseOr, "|") \
  402. S(LessThan, "<") \
  403. S(LessThanEquals, "<=") \
  404. S(GreaterThan, ">") \
  405. S(GreaterThanEquals, ">=") \
  406. S(Equals, "=") \
  407. S(NotEquals, "!=") \
  408. S(And, "and") \
  409. S(Or, "or")
  410. enum class BinaryOperator {
  411. #undef __BinaryOperator
  412. #define __BinaryOperator(code, name) code,
  413. __enum_BinaryOperator(__BinaryOperator)
  414. #undef __BinaryOperator
  415. };
  416. constexpr char const* BinaryOperator_name(BinaryOperator op)
  417. {
  418. switch (op) {
  419. #undef __BinaryOperator
  420. #define __BinaryOperator(code, name) \
  421. case BinaryOperator::code: \
  422. return name;
  423. __enum_BinaryOperator(__BinaryOperator)
  424. #undef __BinaryOperator
  425. default : VERIFY_NOT_REACHED();
  426. }
  427. }
  428. class BinaryOperatorExpression : public NestedDoubleExpression {
  429. public:
  430. BinaryOperatorExpression(BinaryOperator type, NonnullRefPtr<Expression> lhs, NonnullRefPtr<Expression> rhs)
  431. : NestedDoubleExpression(move(lhs), move(rhs))
  432. , m_type(type)
  433. {
  434. }
  435. BinaryOperator type() const { return m_type; }
  436. virtual Value evaluate(ExecutionContext&) const override;
  437. private:
  438. BinaryOperator m_type;
  439. };
  440. class ChainedExpression : public Expression {
  441. public:
  442. explicit ChainedExpression(NonnullRefPtrVector<Expression> expressions)
  443. : m_expressions(move(expressions))
  444. {
  445. }
  446. const NonnullRefPtrVector<Expression>& expressions() const { return m_expressions; }
  447. virtual Value evaluate(ExecutionContext&) const override;
  448. private:
  449. NonnullRefPtrVector<Expression> m_expressions;
  450. };
  451. class CastExpression : public NestedExpression {
  452. public:
  453. CastExpression(NonnullRefPtr<Expression> expression, NonnullRefPtr<TypeName> type_name)
  454. : NestedExpression(move(expression))
  455. , m_type_name(move(type_name))
  456. {
  457. }
  458. const NonnullRefPtr<TypeName>& type_name() const { return m_type_name; }
  459. private:
  460. NonnullRefPtr<TypeName> m_type_name;
  461. };
  462. class CaseExpression : public Expression {
  463. public:
  464. struct WhenThenClause {
  465. NonnullRefPtr<Expression> when;
  466. NonnullRefPtr<Expression> then;
  467. };
  468. CaseExpression(RefPtr<Expression> case_expression, Vector<WhenThenClause> when_then_clauses, RefPtr<Expression> else_expression)
  469. : m_case_expression(case_expression)
  470. , m_when_then_clauses(when_then_clauses)
  471. , m_else_expression(else_expression)
  472. {
  473. VERIFY(!m_when_then_clauses.is_empty());
  474. }
  475. const RefPtr<Expression>& case_expression() const { return m_case_expression; }
  476. const Vector<WhenThenClause>& when_then_clauses() const { return m_when_then_clauses; }
  477. const RefPtr<Expression>& else_expression() const { return m_else_expression; }
  478. private:
  479. RefPtr<Expression> m_case_expression;
  480. Vector<WhenThenClause> m_when_then_clauses;
  481. RefPtr<Expression> m_else_expression;
  482. };
  483. class ExistsExpression : public Expression {
  484. public:
  485. ExistsExpression(NonnullRefPtr<Select> select_statement, bool invert_expression)
  486. : m_select_statement(move(select_statement))
  487. , m_invert_expression(invert_expression)
  488. {
  489. }
  490. const NonnullRefPtr<Select>& select_statement() const { return m_select_statement; }
  491. bool invert_expression() const { return m_invert_expression; }
  492. private:
  493. NonnullRefPtr<Select> m_select_statement;
  494. bool m_invert_expression;
  495. };
  496. class CollateExpression : public NestedExpression {
  497. public:
  498. CollateExpression(NonnullRefPtr<Expression> expression, String collation_name)
  499. : NestedExpression(move(expression))
  500. , m_collation_name(move(collation_name))
  501. {
  502. }
  503. const String& collation_name() const { return m_collation_name; }
  504. private:
  505. String m_collation_name;
  506. };
  507. enum class MatchOperator {
  508. Like,
  509. Glob,
  510. Match,
  511. Regexp,
  512. };
  513. class MatchExpression : public InvertibleNestedDoubleExpression {
  514. public:
  515. MatchExpression(MatchOperator type, NonnullRefPtr<Expression> lhs, NonnullRefPtr<Expression> rhs, RefPtr<Expression> escape, bool invert_expression)
  516. : InvertibleNestedDoubleExpression(move(lhs), move(rhs), invert_expression)
  517. , m_type(type)
  518. , m_escape(move(escape))
  519. {
  520. }
  521. MatchOperator type() const { return m_type; }
  522. const RefPtr<Expression>& escape() const { return m_escape; }
  523. private:
  524. MatchOperator m_type;
  525. RefPtr<Expression> m_escape;
  526. };
  527. class NullExpression : public InvertibleNestedExpression {
  528. public:
  529. NullExpression(NonnullRefPtr<Expression> expression, bool invert_expression)
  530. : InvertibleNestedExpression(move(expression), invert_expression)
  531. {
  532. }
  533. };
  534. class IsExpression : public InvertibleNestedDoubleExpression {
  535. public:
  536. IsExpression(NonnullRefPtr<Expression> lhs, NonnullRefPtr<Expression> rhs, bool invert_expression)
  537. : InvertibleNestedDoubleExpression(move(lhs), move(rhs), invert_expression)
  538. {
  539. }
  540. };
  541. class BetweenExpression : public InvertibleNestedDoubleExpression {
  542. public:
  543. BetweenExpression(NonnullRefPtr<Expression> expression, NonnullRefPtr<Expression> lhs, NonnullRefPtr<Expression> rhs, bool invert_expression)
  544. : InvertibleNestedDoubleExpression(move(lhs), move(rhs), invert_expression)
  545. , m_expression(move(expression))
  546. {
  547. }
  548. const NonnullRefPtr<Expression>& expression() const { return m_expression; }
  549. private:
  550. NonnullRefPtr<Expression> m_expression;
  551. };
  552. class InSelectionExpression : public InvertibleNestedExpression {
  553. public:
  554. InSelectionExpression(NonnullRefPtr<Expression> expression, NonnullRefPtr<Select> select_statement, bool invert_expression)
  555. : InvertibleNestedExpression(move(expression), invert_expression)
  556. , m_select_statement(move(select_statement))
  557. {
  558. }
  559. const NonnullRefPtr<Select>& select_statement() const { return m_select_statement; }
  560. private:
  561. NonnullRefPtr<Select> m_select_statement;
  562. };
  563. class InChainedExpression : public InvertibleNestedExpression {
  564. public:
  565. InChainedExpression(NonnullRefPtr<Expression> expression, NonnullRefPtr<ChainedExpression> expression_chain, bool invert_expression)
  566. : InvertibleNestedExpression(move(expression), invert_expression)
  567. , m_expression_chain(move(expression_chain))
  568. {
  569. }
  570. const NonnullRefPtr<ChainedExpression>& expression_chain() const { return m_expression_chain; }
  571. private:
  572. NonnullRefPtr<ChainedExpression> m_expression_chain;
  573. };
  574. class InTableExpression : public InvertibleNestedExpression {
  575. public:
  576. InTableExpression(NonnullRefPtr<Expression> expression, String schema_name, String table_name, bool invert_expression)
  577. : InvertibleNestedExpression(move(expression), invert_expression)
  578. , m_schema_name(move(schema_name))
  579. , m_table_name(move(table_name))
  580. {
  581. }
  582. const String& schema_name() const { return m_schema_name; }
  583. const String& table_name() const { return m_table_name; }
  584. private:
  585. String m_schema_name;
  586. String m_table_name;
  587. };
  588. //==================================================================================================
  589. // Statements
  590. //==================================================================================================
  591. class Statement : public ASTNode {
  592. public:
  593. RefPtr<SQLResult> execute(AK::NonnullRefPtr<Database> database) const;
  594. virtual RefPtr<SQLResult> execute(ExecutionContext&) const { return nullptr; }
  595. };
  596. class ErrorStatement final : public Statement {
  597. };
  598. class CreateSchema : public Statement {
  599. public:
  600. CreateSchema(String schema_name, bool is_error_if_schema_exists)
  601. : m_schema_name(move(schema_name))
  602. , m_is_error_if_schema_exists(is_error_if_schema_exists)
  603. {
  604. }
  605. const String& schema_name() const { return m_schema_name; }
  606. bool is_error_if_schema_exists() const { return m_is_error_if_schema_exists; }
  607. RefPtr<SQLResult> execute(ExecutionContext&) const override;
  608. private:
  609. String m_schema_name;
  610. bool m_is_error_if_schema_exists;
  611. };
  612. class CreateTable : public Statement {
  613. public:
  614. CreateTable(String schema_name, String table_name, RefPtr<Select> select_statement, bool is_temporary, bool is_error_if_table_exists)
  615. : m_schema_name(move(schema_name))
  616. , m_table_name(move(table_name))
  617. , m_select_statement(move(select_statement))
  618. , m_is_temporary(is_temporary)
  619. , m_is_error_if_table_exists(is_error_if_table_exists)
  620. {
  621. }
  622. CreateTable(String schema_name, String table_name, NonnullRefPtrVector<ColumnDefinition> columns, bool is_temporary, bool is_error_if_table_exists)
  623. : m_schema_name(move(schema_name))
  624. , m_table_name(move(table_name))
  625. , m_columns(move(columns))
  626. , m_is_temporary(is_temporary)
  627. , m_is_error_if_table_exists(is_error_if_table_exists)
  628. {
  629. }
  630. const String& schema_name() const { return m_schema_name; }
  631. const String& table_name() const { return m_table_name; }
  632. bool has_selection() const { return !m_select_statement.is_null(); }
  633. const RefPtr<Select>& select_statement() const { return m_select_statement; }
  634. bool has_columns() const { return !m_columns.is_empty(); }
  635. const NonnullRefPtrVector<ColumnDefinition>& columns() const { return m_columns; }
  636. bool is_temporary() const { return m_is_temporary; }
  637. bool is_error_if_table_exists() const { return m_is_error_if_table_exists; }
  638. RefPtr<SQLResult> execute(ExecutionContext&) const override;
  639. private:
  640. String m_schema_name;
  641. String m_table_name;
  642. RefPtr<Select> m_select_statement;
  643. NonnullRefPtrVector<ColumnDefinition> m_columns;
  644. bool m_is_temporary;
  645. bool m_is_error_if_table_exists;
  646. };
  647. class AlterTable : public Statement {
  648. public:
  649. const String& schema_name() const { return m_schema_name; }
  650. const String& table_name() const { return m_table_name; }
  651. protected:
  652. AlterTable(String schema_name, String table_name)
  653. : m_schema_name(move(schema_name))
  654. , m_table_name(move(table_name))
  655. {
  656. }
  657. private:
  658. String m_schema_name;
  659. String m_table_name;
  660. };
  661. class RenameTable : public AlterTable {
  662. public:
  663. RenameTable(String schema_name, String table_name, String new_table_name)
  664. : AlterTable(move(schema_name), move(table_name))
  665. , m_new_table_name(move(new_table_name))
  666. {
  667. }
  668. const String& new_table_name() const { return m_new_table_name; }
  669. private:
  670. String m_new_table_name;
  671. };
  672. class RenameColumn : public AlterTable {
  673. public:
  674. RenameColumn(String schema_name, String table_name, String column_name, String new_column_name)
  675. : AlterTable(move(schema_name), move(table_name))
  676. , m_column_name(move(column_name))
  677. , m_new_column_name(move(new_column_name))
  678. {
  679. }
  680. const String& column_name() const { return m_column_name; }
  681. const String& new_column_name() const { return m_new_column_name; }
  682. private:
  683. String m_column_name;
  684. String m_new_column_name;
  685. };
  686. class AddColumn : public AlterTable {
  687. public:
  688. AddColumn(String schema_name, String table_name, NonnullRefPtr<ColumnDefinition> column)
  689. : AlterTable(move(schema_name), move(table_name))
  690. , m_column(move(column))
  691. {
  692. }
  693. const NonnullRefPtr<ColumnDefinition>& column() const { return m_column; }
  694. private:
  695. NonnullRefPtr<ColumnDefinition> m_column;
  696. };
  697. class DropColumn : public AlterTable {
  698. public:
  699. DropColumn(String schema_name, String table_name, String column_name)
  700. : AlterTable(move(schema_name), move(table_name))
  701. , m_column_name(move(column_name))
  702. {
  703. }
  704. const String& column_name() const { return m_column_name; }
  705. private:
  706. String m_column_name;
  707. };
  708. class DropTable : public Statement {
  709. public:
  710. DropTable(String schema_name, String table_name, bool is_error_if_table_does_not_exist)
  711. : m_schema_name(move(schema_name))
  712. , m_table_name(move(table_name))
  713. , m_is_error_if_table_does_not_exist(is_error_if_table_does_not_exist)
  714. {
  715. }
  716. const String& schema_name() const { return m_schema_name; }
  717. const String& table_name() const { return m_table_name; }
  718. bool is_error_if_table_does_not_exist() const { return m_is_error_if_table_does_not_exist; }
  719. private:
  720. String m_schema_name;
  721. String m_table_name;
  722. bool m_is_error_if_table_does_not_exist;
  723. };
  724. enum class ConflictResolution {
  725. Abort,
  726. Fail,
  727. Ignore,
  728. Replace,
  729. Rollback,
  730. };
  731. class Insert : public Statement {
  732. public:
  733. Insert(RefPtr<CommonTableExpressionList> common_table_expression_list, ConflictResolution conflict_resolution, String schema_name, String table_name, String alias, Vector<String> column_names, NonnullRefPtrVector<ChainedExpression> chained_expressions)
  734. : m_common_table_expression_list(move(common_table_expression_list))
  735. , m_conflict_resolution(conflict_resolution)
  736. , m_schema_name(move(schema_name))
  737. , m_table_name(move(table_name))
  738. , m_alias(move(alias))
  739. , m_column_names(move(column_names))
  740. , m_chained_expressions(move(chained_expressions))
  741. {
  742. }
  743. Insert(RefPtr<CommonTableExpressionList> common_table_expression_list, ConflictResolution conflict_resolution, String schema_name, String table_name, String alias, Vector<String> column_names, RefPtr<Select> select_statement)
  744. : m_common_table_expression_list(move(common_table_expression_list))
  745. , m_conflict_resolution(conflict_resolution)
  746. , m_schema_name(move(schema_name))
  747. , m_table_name(move(table_name))
  748. , m_alias(move(alias))
  749. , m_column_names(move(column_names))
  750. , m_select_statement(move(select_statement))
  751. {
  752. }
  753. Insert(RefPtr<CommonTableExpressionList> common_table_expression_list, ConflictResolution conflict_resolution, String schema_name, String table_name, String alias, Vector<String> column_names)
  754. : m_common_table_expression_list(move(common_table_expression_list))
  755. , m_conflict_resolution(conflict_resolution)
  756. , m_schema_name(move(schema_name))
  757. , m_table_name(move(table_name))
  758. , m_alias(move(alias))
  759. , m_column_names(move(column_names))
  760. {
  761. }
  762. const RefPtr<CommonTableExpressionList>& common_table_expression_list() const { return m_common_table_expression_list; }
  763. ConflictResolution conflict_resolution() const { return m_conflict_resolution; }
  764. const String& schema_name() const { return m_schema_name; }
  765. const String& table_name() const { return m_table_name; }
  766. const String& alias() const { return m_alias; }
  767. const Vector<String>& column_names() const { return m_column_names; }
  768. bool default_values() const { return !has_expressions() && !has_selection(); };
  769. bool has_expressions() const { return !m_chained_expressions.is_empty(); }
  770. const NonnullRefPtrVector<ChainedExpression>& chained_expressions() const { return m_chained_expressions; }
  771. bool has_selection() const { return !m_select_statement.is_null(); }
  772. const RefPtr<Select>& select_statement() const { return m_select_statement; }
  773. virtual RefPtr<SQLResult> execute(ExecutionContext&) const override;
  774. private:
  775. RefPtr<CommonTableExpressionList> m_common_table_expression_list;
  776. ConflictResolution m_conflict_resolution;
  777. String m_schema_name;
  778. String m_table_name;
  779. String m_alias;
  780. Vector<String> m_column_names;
  781. NonnullRefPtrVector<ChainedExpression> m_chained_expressions;
  782. RefPtr<Select> m_select_statement;
  783. };
  784. class Update : public Statement {
  785. public:
  786. struct UpdateColumns {
  787. Vector<String> column_names;
  788. NonnullRefPtr<Expression> expression;
  789. };
  790. Update(RefPtr<CommonTableExpressionList> common_table_expression_list, ConflictResolution conflict_resolution, NonnullRefPtr<QualifiedTableName> qualified_table_name, Vector<UpdateColumns> update_columns, NonnullRefPtrVector<TableOrSubquery> table_or_subquery_list, RefPtr<Expression> where_clause, RefPtr<ReturningClause> returning_clause)
  791. : m_common_table_expression_list(move(common_table_expression_list))
  792. , m_conflict_resolution(conflict_resolution)
  793. , m_qualified_table_name(move(qualified_table_name))
  794. , m_update_columns(move(update_columns))
  795. , m_table_or_subquery_list(move(table_or_subquery_list))
  796. , m_where_clause(move(where_clause))
  797. , m_returning_clause(move(returning_clause))
  798. {
  799. }
  800. const RefPtr<CommonTableExpressionList>& common_table_expression_list() const { return m_common_table_expression_list; }
  801. ConflictResolution conflict_resolution() const { return m_conflict_resolution; }
  802. const NonnullRefPtr<QualifiedTableName>& qualified_table_name() const { return m_qualified_table_name; }
  803. const Vector<UpdateColumns>& update_columns() const { return m_update_columns; }
  804. const NonnullRefPtrVector<TableOrSubquery>& table_or_subquery_list() const { return m_table_or_subquery_list; }
  805. const RefPtr<Expression>& where_clause() const { return m_where_clause; }
  806. const RefPtr<ReturningClause>& returning_clause() const { return m_returning_clause; }
  807. private:
  808. RefPtr<CommonTableExpressionList> m_common_table_expression_list;
  809. ConflictResolution m_conflict_resolution;
  810. NonnullRefPtr<QualifiedTableName> m_qualified_table_name;
  811. Vector<UpdateColumns> m_update_columns;
  812. NonnullRefPtrVector<TableOrSubquery> m_table_or_subquery_list;
  813. RefPtr<Expression> m_where_clause;
  814. RefPtr<ReturningClause> m_returning_clause;
  815. };
  816. class Delete : public Statement {
  817. public:
  818. Delete(RefPtr<CommonTableExpressionList> common_table_expression_list, NonnullRefPtr<QualifiedTableName> qualified_table_name, RefPtr<Expression> where_clause, RefPtr<ReturningClause> returning_clause)
  819. : m_common_table_expression_list(move(common_table_expression_list))
  820. , m_qualified_table_name(move(qualified_table_name))
  821. , m_where_clause(move(where_clause))
  822. , m_returning_clause(move(returning_clause))
  823. {
  824. }
  825. const RefPtr<CommonTableExpressionList>& common_table_expression_list() const { return m_common_table_expression_list; }
  826. const NonnullRefPtr<QualifiedTableName>& qualified_table_name() const { return m_qualified_table_name; }
  827. const RefPtr<Expression>& where_clause() const { return m_where_clause; }
  828. const RefPtr<ReturningClause>& returning_clause() const { return m_returning_clause; }
  829. private:
  830. RefPtr<CommonTableExpressionList> m_common_table_expression_list;
  831. NonnullRefPtr<QualifiedTableName> m_qualified_table_name;
  832. RefPtr<Expression> m_where_clause;
  833. RefPtr<ReturningClause> m_returning_clause;
  834. };
  835. class Select : public Statement {
  836. public:
  837. Select(RefPtr<CommonTableExpressionList> common_table_expression_list, bool select_all, NonnullRefPtrVector<ResultColumn> result_column_list, NonnullRefPtrVector<TableOrSubquery> table_or_subquery_list, RefPtr<Expression> where_clause, RefPtr<GroupByClause> group_by_clause, NonnullRefPtrVector<OrderingTerm> ordering_term_list, RefPtr<LimitClause> limit_clause)
  838. : m_common_table_expression_list(move(common_table_expression_list))
  839. , m_select_all(move(select_all))
  840. , m_result_column_list(move(result_column_list))
  841. , m_table_or_subquery_list(move(table_or_subquery_list))
  842. , m_where_clause(move(where_clause))
  843. , m_group_by_clause(move(group_by_clause))
  844. , m_ordering_term_list(move(ordering_term_list))
  845. , m_limit_clause(move(limit_clause))
  846. {
  847. }
  848. const RefPtr<CommonTableExpressionList>& common_table_expression_list() const { return m_common_table_expression_list; }
  849. bool select_all() const { return m_select_all; }
  850. const NonnullRefPtrVector<ResultColumn>& result_column_list() const { return m_result_column_list; }
  851. const NonnullRefPtrVector<TableOrSubquery>& table_or_subquery_list() const { return m_table_or_subquery_list; }
  852. const RefPtr<Expression>& where_clause() const { return m_where_clause; }
  853. const RefPtr<GroupByClause>& group_by_clause() const { return m_group_by_clause; }
  854. const NonnullRefPtrVector<OrderingTerm>& ordering_term_list() const { return m_ordering_term_list; }
  855. const RefPtr<LimitClause>& limit_clause() const { return m_limit_clause; }
  856. RefPtr<SQLResult> execute(ExecutionContext&) const override;
  857. private:
  858. RefPtr<CommonTableExpressionList> m_common_table_expression_list;
  859. bool m_select_all;
  860. NonnullRefPtrVector<ResultColumn> m_result_column_list;
  861. NonnullRefPtrVector<TableOrSubquery> m_table_or_subquery_list;
  862. RefPtr<Expression> m_where_clause;
  863. RefPtr<GroupByClause> m_group_by_clause;
  864. NonnullRefPtrVector<OrderingTerm> m_ordering_term_list;
  865. RefPtr<LimitClause> m_limit_clause;
  866. };
  867. }