AST.h 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008
  1. /*
  2. * Copyright (c) 2021, Itamar S. <itamar8910@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/FlyString.h>
  8. #include <AK/NonnullRefPtrVector.h>
  9. #include <AK/Optional.h>
  10. #include <AK/RefCounted.h>
  11. #include <AK/String.h>
  12. #include <AK/TypeCasts.h>
  13. #include <AK/Vector.h>
  14. #include <LibCpp/Lexer.h>
  15. namespace Cpp {
  16. class ASTNode;
  17. class TranslationUnit;
  18. class Declaration;
  19. class FunctionDefinition;
  20. class Type;
  21. class Parameter;
  22. class Statement;
  23. class Name;
  24. class ASTNode : public RefCounted<ASTNode> {
  25. public:
  26. virtual ~ASTNode() = default;
  27. virtual const char* class_name() const = 0;
  28. virtual void dump(FILE* = stdout, size_t indent = 0) const;
  29. template<typename T>
  30. bool fast_is() const = delete;
  31. ASTNode* parent() const { return m_parent; }
  32. Position start() const
  33. {
  34. VERIFY(m_start.has_value());
  35. return m_start.value();
  36. }
  37. Position end() const
  38. {
  39. VERIFY(m_end.has_value());
  40. return m_end.value();
  41. }
  42. const FlyString& filename() const
  43. {
  44. return m_filename;
  45. }
  46. void set_end(const Position& end) { m_end = end; }
  47. void set_parent(ASTNode& parent) { m_parent = &parent; }
  48. virtual NonnullRefPtrVector<Declaration> declarations() const { return {}; }
  49. virtual bool is_identifier() const { return false; }
  50. virtual bool is_member_expression() const { return false; }
  51. virtual bool is_variable_or_parameter_declaration() const { return false; }
  52. virtual bool is_function_call() const { return false; }
  53. virtual bool is_type() const { return false; }
  54. virtual bool is_declaration() const { return false; }
  55. virtual bool is_name() const { return false; }
  56. virtual bool is_dummy_node() const { return false; }
  57. protected:
  58. ASTNode(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  59. : m_parent(parent)
  60. , m_start(start)
  61. , m_end(end)
  62. , m_filename(filename)
  63. {
  64. }
  65. private:
  66. ASTNode* m_parent { nullptr };
  67. Optional<Position> m_start;
  68. Optional<Position> m_end;
  69. FlyString m_filename;
  70. };
  71. class TranslationUnit : public ASTNode {
  72. public:
  73. virtual ~TranslationUnit() override = default;
  74. virtual const char* class_name() const override { return "TranslationUnit"; }
  75. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  76. virtual NonnullRefPtrVector<Declaration> declarations() const override { return m_declarations; }
  77. TranslationUnit(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  78. : ASTNode(parent, start, end, filename)
  79. {
  80. }
  81. void set_declarations(NonnullRefPtrVector<Declaration>&& declarations) { m_declarations = move(declarations); }
  82. private:
  83. NonnullRefPtrVector<Declaration> m_declarations;
  84. };
  85. class Statement : public ASTNode {
  86. public:
  87. virtual ~Statement() override = default;
  88. virtual const char* class_name() const override { return "Statement"; }
  89. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  90. protected:
  91. Statement(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  92. : ASTNode(parent, start, end, filename)
  93. {
  94. }
  95. };
  96. class Declaration : public Statement {
  97. public:
  98. virtual bool is_declaration() const override { return true; }
  99. virtual bool is_variable_declaration() const { return false; }
  100. virtual bool is_parameter() const { return false; }
  101. virtual bool is_struct_or_class() const { return false; }
  102. virtual bool is_struct() const { return false; }
  103. virtual bool is_class() const { return false; }
  104. virtual bool is_function() const { return false; }
  105. virtual bool is_namespace() const { return false; }
  106. virtual bool is_enum() const { return false; }
  107. bool is_member() const { return parent() != nullptr && parent()->is_declaration() && verify_cast<Declaration>(parent())->is_struct_or_class(); }
  108. const Name* name() const { return m_name; }
  109. StringView full_name() const;
  110. void set_name(RefPtr<Name> name) { m_name = move(name); }
  111. protected:
  112. Declaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  113. : Statement(parent, start, end, filename)
  114. {
  115. }
  116. RefPtr<Name> m_name;
  117. mutable Optional<String> m_full_name;
  118. };
  119. class InvalidDeclaration : public Declaration {
  120. public:
  121. virtual ~InvalidDeclaration() override = default;
  122. virtual const char* class_name() const override { return "InvalidDeclaration"; }
  123. InvalidDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  124. : Declaration(parent, start, end, filename)
  125. {
  126. }
  127. };
  128. class FunctionDeclaration : public Declaration {
  129. public:
  130. virtual ~FunctionDeclaration() override = default;
  131. virtual const char* class_name() const override { return "FunctionDeclaration"; }
  132. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  133. virtual bool is_function() const override { return true; }
  134. virtual bool is_constructor() const { return false; }
  135. virtual bool is_destructor() const { return false; }
  136. RefPtr<FunctionDefinition> definition() { return m_definition; }
  137. FunctionDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  138. : Declaration(parent, start, end, filename)
  139. {
  140. }
  141. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  142. const Vector<StringView>& qualifiers() const { return m_qualifiers; }
  143. void set_qualifiers(const Vector<StringView>& qualifiers) { m_qualifiers = qualifiers; }
  144. const Type* return_type() const { return m_return_type.ptr(); }
  145. void set_return_type(const RefPtr<Type>& return_type) { m_return_type = return_type; }
  146. const NonnullRefPtrVector<Parameter>& parameters() const { return m_parameters; }
  147. void set_parameters(const NonnullRefPtrVector<Parameter>& parameters) { m_parameters = parameters; }
  148. const FunctionDefinition* definition() const { return m_definition.ptr(); }
  149. void set_definition(RefPtr<FunctionDefinition>&& definition) { m_definition = move(definition); }
  150. private:
  151. Vector<StringView> m_qualifiers;
  152. RefPtr<Type> m_return_type;
  153. NonnullRefPtrVector<Parameter> m_parameters;
  154. RefPtr<FunctionDefinition> m_definition;
  155. };
  156. class VariableOrParameterDeclaration : public Declaration {
  157. public:
  158. virtual ~VariableOrParameterDeclaration() override = default;
  159. virtual bool is_variable_or_parameter_declaration() const override { return true; }
  160. void set_type(RefPtr<Type>&& type) { m_type = move(type); }
  161. const Type* type() const { return m_type.ptr(); }
  162. protected:
  163. VariableOrParameterDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  164. : Declaration(parent, start, end, filename)
  165. {
  166. }
  167. RefPtr<Type> m_type;
  168. };
  169. class Parameter : public VariableOrParameterDeclaration {
  170. public:
  171. virtual ~Parameter() override = default;
  172. virtual const char* class_name() const override { return "Parameter"; }
  173. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  174. virtual bool is_parameter() const override { return true; }
  175. Parameter(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename, RefPtr<Name> name)
  176. : VariableOrParameterDeclaration(parent, start, end, filename)
  177. {
  178. m_name = name;
  179. }
  180. bool is_ellipsis() const { return m_is_ellipsis; }
  181. void set_ellipsis(bool is_ellipsis) { m_is_ellipsis = is_ellipsis; }
  182. private:
  183. bool m_is_ellipsis { false };
  184. };
  185. class Type : public ASTNode {
  186. public:
  187. virtual ~Type() override = default;
  188. virtual const char* class_name() const override { return "Type"; }
  189. virtual bool is_type() const override { return true; }
  190. virtual bool is_templatized() const { return false; }
  191. virtual bool is_named_type() const { return false; }
  192. virtual String to_string() const = 0;
  193. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  194. bool is_auto() const { return m_is_auto; }
  195. void set_auto(bool is_auto) { m_is_auto = is_auto; }
  196. Vector<StringView> const& qualifiers() const { return m_qualifiers; }
  197. void set_qualifiers(Vector<StringView>&& qualifiers) { m_qualifiers = move(qualifiers); }
  198. protected:
  199. Type(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  200. : ASTNode(parent, start, end, filename)
  201. {
  202. }
  203. private:
  204. bool m_is_auto { false };
  205. Vector<StringView> m_qualifiers;
  206. };
  207. class NamedType : public Type {
  208. public:
  209. virtual ~NamedType() override = default;
  210. virtual const char* class_name() const override { return "NamedType"; }
  211. virtual String to_string() const override;
  212. virtual bool is_named_type() const override { return true; }
  213. NamedType(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  214. : Type(parent, start, end, filename)
  215. {
  216. }
  217. const Name* name() const { return m_name.ptr(); }
  218. void set_name(RefPtr<Name>&& name) { m_name = move(name); }
  219. private:
  220. RefPtr<Name> m_name;
  221. };
  222. class Pointer : public Type {
  223. public:
  224. virtual ~Pointer() override = default;
  225. virtual const char* class_name() const override { return "Pointer"; }
  226. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  227. virtual String to_string() const override;
  228. Pointer(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  229. : Type(parent, start, end, filename)
  230. {
  231. }
  232. const Type* pointee() const { return m_pointee.ptr(); }
  233. void set_pointee(RefPtr<Type>&& pointee) { m_pointee = move(pointee); }
  234. private:
  235. RefPtr<Type> m_pointee;
  236. };
  237. class Reference : public Type {
  238. public:
  239. virtual ~Reference() override = default;
  240. virtual const char* class_name() const override { return "Reference"; }
  241. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  242. virtual String to_string() const override;
  243. enum class Kind {
  244. Lvalue,
  245. Rvalue,
  246. };
  247. Reference(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename, Kind kind)
  248. : Type(parent, start, end, filename)
  249. , m_kind(kind)
  250. {
  251. }
  252. const Type* referenced_type() const { return m_referenced_type.ptr(); }
  253. void set_referenced_type(RefPtr<Type>&& pointee) { m_referenced_type = move(pointee); }
  254. Kind kind() const { return m_kind; }
  255. private:
  256. RefPtr<Type const> m_referenced_type;
  257. Kind m_kind;
  258. };
  259. class FunctionType : public Type {
  260. public:
  261. virtual ~FunctionType() override = default;
  262. virtual const char* class_name() const override { return "FunctionType"; }
  263. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  264. virtual String to_string() const override;
  265. FunctionType(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  266. : Type(parent, start, end, filename)
  267. {
  268. }
  269. void set_return_type(Type& type) { m_return_type = type; }
  270. void set_parameters(NonnullRefPtrVector<Parameter> parameters) { m_parameters = move(parameters); }
  271. private:
  272. RefPtr<Type> m_return_type;
  273. NonnullRefPtrVector<Parameter> m_parameters;
  274. };
  275. class FunctionDefinition : public ASTNode {
  276. public:
  277. virtual ~FunctionDefinition() override = default;
  278. virtual const char* class_name() const override { return "FunctionDefinition"; }
  279. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  280. FunctionDefinition(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  281. : ASTNode(parent, start, end, filename)
  282. {
  283. }
  284. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  285. NonnullRefPtrVector<Statement> const& statements() { return m_statements; }
  286. void add_statement(NonnullRefPtr<Statement>&& statement) { m_statements.append(move(statement)); }
  287. private:
  288. NonnullRefPtrVector<Statement> m_statements;
  289. };
  290. class InvalidStatement : public Statement {
  291. public:
  292. virtual ~InvalidStatement() override = default;
  293. virtual const char* class_name() const override { return "InvalidStatement"; }
  294. InvalidStatement(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  295. : Statement(parent, start, end, filename)
  296. {
  297. }
  298. };
  299. class Expression : public Statement {
  300. public:
  301. virtual ~Expression() override = default;
  302. virtual const char* class_name() const override { return "Expression"; }
  303. protected:
  304. Expression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  305. : Statement(parent, start, end, filename)
  306. {
  307. }
  308. };
  309. class InvalidExpression : public Expression {
  310. public:
  311. virtual ~InvalidExpression() override = default;
  312. virtual const char* class_name() const override { return "InvalidExpression"; }
  313. InvalidExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  314. : Expression(parent, start, end, filename)
  315. {
  316. }
  317. };
  318. class VariableDeclaration : public VariableOrParameterDeclaration {
  319. public:
  320. virtual ~VariableDeclaration() override = default;
  321. virtual const char* class_name() const override { return "VariableDeclaration"; }
  322. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  323. VariableDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  324. : VariableOrParameterDeclaration(parent, start, end, filename)
  325. {
  326. }
  327. virtual bool is_variable_declaration() const override { return true; }
  328. const Expression* initial_value() const { return m_initial_value; }
  329. void set_initial_value(RefPtr<Expression>&& initial_value) { m_initial_value = move(initial_value); }
  330. private:
  331. RefPtr<Expression> m_initial_value;
  332. };
  333. class Identifier : public Expression {
  334. public:
  335. virtual ~Identifier() override = default;
  336. virtual const char* class_name() const override { return "Identifier"; }
  337. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  338. Identifier(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename, StringView name)
  339. : Expression(parent, start, end, filename)
  340. , m_name(name)
  341. {
  342. }
  343. Identifier(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  344. : Identifier(parent, start, end, filename, {})
  345. {
  346. }
  347. virtual bool is_identifier() const override { return true; }
  348. StringView name() const { return m_name; }
  349. void set_name(StringView&& name) { m_name = move(name); }
  350. private:
  351. StringView m_name;
  352. };
  353. class Name : public Expression {
  354. public:
  355. virtual ~Name() override = default;
  356. virtual const char* class_name() const override { return "Name"; }
  357. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  358. virtual bool is_name() const override { return true; }
  359. virtual bool is_templatized() const { return false; }
  360. Name(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  361. : Expression(parent, start, end, filename)
  362. {
  363. }
  364. virtual StringView full_name() const;
  365. const Identifier* name() const { return m_name.ptr(); }
  366. void set_name(RefPtr<Identifier>&& name) { m_name = move(name); }
  367. NonnullRefPtrVector<Identifier> const& scope() const { return m_scope; }
  368. void set_scope(NonnullRefPtrVector<Identifier> scope) { m_scope = move(scope); }
  369. void add_to_scope(NonnullRefPtr<Identifier>&& part) { m_scope.append(move(part)); }
  370. private:
  371. RefPtr<Identifier> m_name;
  372. NonnullRefPtrVector<Identifier> m_scope;
  373. mutable Optional<String> m_full_name;
  374. };
  375. class TemplatizedName : public Name {
  376. public:
  377. virtual ~TemplatizedName() override = default;
  378. virtual const char* class_name() const override { return "TemplatizedName"; }
  379. virtual bool is_templatized() const override { return true; }
  380. virtual StringView full_name() const override;
  381. TemplatizedName(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  382. : Name(parent, start, end, filename)
  383. {
  384. }
  385. void add_template_argument(NonnullRefPtr<Type>&& type) { m_template_arguments.append(move(type)); }
  386. private:
  387. NonnullRefPtrVector<Type> m_template_arguments;
  388. mutable Optional<String> m_full_name;
  389. };
  390. class NumericLiteral : public Expression {
  391. public:
  392. virtual ~NumericLiteral() override = default;
  393. virtual const char* class_name() const override { return "NumericLiteral"; }
  394. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  395. NumericLiteral(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename, StringView value)
  396. : Expression(parent, start, end, filename)
  397. , m_value(value)
  398. {
  399. }
  400. private:
  401. StringView m_value;
  402. };
  403. class NullPointerLiteral : public Expression {
  404. public:
  405. virtual ~NullPointerLiteral() override = default;
  406. virtual const char* class_name() const override { return "NullPointerLiteral"; }
  407. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  408. NullPointerLiteral(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  409. : Expression(parent, start, end, filename)
  410. {
  411. }
  412. };
  413. class BooleanLiteral : public Expression {
  414. public:
  415. virtual ~BooleanLiteral() override = default;
  416. virtual const char* class_name() const override { return "BooleanLiteral"; }
  417. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  418. BooleanLiteral(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename, bool value)
  419. : Expression(parent, start, end, filename)
  420. , m_value(value)
  421. {
  422. }
  423. private:
  424. bool m_value;
  425. };
  426. enum class BinaryOp {
  427. Addition,
  428. Subtraction,
  429. Multiplication,
  430. Division,
  431. Modulo,
  432. GreaterThan,
  433. GreaterThanEquals,
  434. LessThan,
  435. LessThanEquals,
  436. BitwiseAnd,
  437. BitwiseOr,
  438. BitwiseXor,
  439. LeftShift,
  440. RightShift,
  441. EqualsEquals,
  442. NotEqual,
  443. LogicalOr,
  444. LogicalAnd,
  445. Arrow,
  446. };
  447. class BinaryExpression : public Expression {
  448. public:
  449. BinaryExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  450. : Expression(parent, start, end, filename)
  451. {
  452. }
  453. virtual ~BinaryExpression() override = default;
  454. virtual const char* class_name() const override { return "BinaryExpression"; }
  455. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  456. BinaryOp op() const { return m_op; }
  457. void set_op(BinaryOp op) { m_op = op; }
  458. Expression const* lhs() const { return m_lhs.ptr(); }
  459. void set_lhs(RefPtr<Expression>&& e) { m_lhs = move(e); }
  460. Expression const* rhs() const { return m_rhs.ptr(); }
  461. void set_rhs(RefPtr<Expression>&& e) { m_rhs = move(e); }
  462. private:
  463. BinaryOp m_op;
  464. RefPtr<Expression> m_lhs;
  465. RefPtr<Expression> m_rhs;
  466. };
  467. enum class AssignmentOp {
  468. Assignment,
  469. AdditionAssignment,
  470. SubtractionAssignment,
  471. };
  472. class AssignmentExpression : public Expression {
  473. public:
  474. AssignmentExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  475. : Expression(parent, start, end, filename)
  476. {
  477. }
  478. virtual ~AssignmentExpression() override = default;
  479. virtual const char* class_name() const override { return "AssignmentExpression"; }
  480. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  481. AssignmentOp op() const { return m_op; }
  482. void set_op(AssignmentOp op) { m_op = op; }
  483. const Expression* lhs() const { return m_lhs; }
  484. void set_lhs(RefPtr<Expression>&& e) { m_lhs = move(e); }
  485. const Expression* rhs() const { return m_rhs; }
  486. void set_rhs(RefPtr<Expression>&& e) { m_rhs = move(e); }
  487. private:
  488. AssignmentOp m_op {};
  489. RefPtr<Expression> m_lhs;
  490. RefPtr<Expression> m_rhs;
  491. };
  492. class FunctionCall : public Expression {
  493. public:
  494. FunctionCall(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  495. : Expression(parent, start, end, filename)
  496. {
  497. }
  498. virtual ~FunctionCall() override = default;
  499. virtual const char* class_name() const override { return "FunctionCall"; }
  500. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  501. virtual bool is_function_call() const override { return true; }
  502. const Expression* callee() const { return m_callee.ptr(); }
  503. void set_callee(RefPtr<Expression>&& callee) { m_callee = move(callee); }
  504. void add_argument(NonnullRefPtr<Expression>&& arg) { m_arguments.append(move(arg)); }
  505. NonnullRefPtrVector<Expression> const& arguments() const { return m_arguments; }
  506. private:
  507. RefPtr<Expression> m_callee;
  508. NonnullRefPtrVector<Expression> m_arguments;
  509. };
  510. class StringLiteral final : public Expression {
  511. public:
  512. StringLiteral(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  513. : Expression(parent, start, end, filename)
  514. {
  515. }
  516. ~StringLiteral() override = default;
  517. virtual const char* class_name() const override { return "StringLiteral"; }
  518. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  519. String const& value() const { return m_value; }
  520. void set_value(String value) { m_value = move(value); }
  521. private:
  522. String m_value;
  523. };
  524. class ReturnStatement : public Statement {
  525. public:
  526. virtual ~ReturnStatement() override = default;
  527. virtual const char* class_name() const override { return "ReturnStatement"; }
  528. ReturnStatement(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  529. : Statement(parent, start, end, filename)
  530. {
  531. }
  532. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  533. const Expression* value() const { return m_value.ptr(); }
  534. void set_value(RefPtr<Expression>&& value) { m_value = move(value); }
  535. private:
  536. RefPtr<Expression> m_value;
  537. };
  538. class EnumDeclaration : public Declaration {
  539. public:
  540. virtual ~EnumDeclaration() override = default;
  541. virtual const char* class_name() const override { return "EnumDeclaration"; }
  542. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  543. virtual bool is_enum() const override { return true; }
  544. EnumDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  545. : Declaration(parent, start, end, filename)
  546. {
  547. }
  548. enum class Type {
  549. RegularEnum,
  550. EnumClass
  551. };
  552. void set_type(Type type) { m_type = type; }
  553. void add_entry(StringView entry, RefPtr<Expression> value = nullptr) { m_entries.append({ entry, move(value) }); }
  554. private:
  555. Type m_type { Type::RegularEnum };
  556. struct EnumerationEntry {
  557. StringView name;
  558. RefPtr<Expression> value;
  559. };
  560. Vector<EnumerationEntry> m_entries;
  561. };
  562. class StructOrClassDeclaration : public Declaration {
  563. public:
  564. virtual ~StructOrClassDeclaration() override = default;
  565. virtual const char* class_name() const override { return "StructOrClassDeclaration"; }
  566. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  567. virtual bool is_struct_or_class() const override { return true; }
  568. virtual bool is_struct() const override { return m_type == Type::Struct; }
  569. virtual bool is_class() const override { return m_type == Type::Class; }
  570. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  571. enum class Type {
  572. Struct,
  573. Class
  574. };
  575. StructOrClassDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename, StructOrClassDeclaration::Type type)
  576. : Declaration(parent, start, end, filename)
  577. , m_type(type)
  578. {
  579. }
  580. NonnullRefPtrVector<Declaration> const& members() const { return m_members; }
  581. void set_members(NonnullRefPtrVector<Declaration>&& members) { m_members = move(members); }
  582. private:
  583. StructOrClassDeclaration::Type m_type;
  584. NonnullRefPtrVector<Declaration> m_members;
  585. };
  586. enum class UnaryOp {
  587. Invalid,
  588. BitwiseNot,
  589. Not,
  590. Plus,
  591. Minus,
  592. PlusPlus,
  593. Address,
  594. };
  595. class UnaryExpression : public Expression {
  596. public:
  597. UnaryExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  598. : Expression(parent, start, end, filename)
  599. {
  600. }
  601. virtual ~UnaryExpression() override = default;
  602. virtual const char* class_name() const override { return "UnaryExpression"; }
  603. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  604. void set_op(UnaryOp op) { m_op = op; }
  605. void set_lhs(RefPtr<Expression>&& e) { m_lhs = move(e); }
  606. private:
  607. UnaryOp m_op;
  608. RefPtr<Expression> m_lhs;
  609. };
  610. class MemberExpression : public Expression {
  611. public:
  612. MemberExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  613. : Expression(parent, start, end, filename)
  614. {
  615. }
  616. virtual ~MemberExpression() override = default;
  617. virtual const char* class_name() const override { return "MemberExpression"; }
  618. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  619. virtual bool is_member_expression() const override { return true; }
  620. const Expression* object() const { return m_object.ptr(); }
  621. void set_object(RefPtr<Expression>&& object) { m_object = move(object); }
  622. const Expression* property() const { return m_property.ptr(); }
  623. void set_property(RefPtr<Expression>&& property) { m_property = move(property); }
  624. private:
  625. RefPtr<Expression> m_object;
  626. RefPtr<Expression> m_property;
  627. };
  628. class ForStatement : public Statement {
  629. public:
  630. ForStatement(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  631. : Statement(parent, start, end, filename)
  632. {
  633. }
  634. virtual ~ForStatement() override = default;
  635. virtual const char* class_name() const override { return "ForStatement"; }
  636. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  637. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  638. void set_init(RefPtr<VariableDeclaration>&& init) { m_init = move(init); }
  639. void set_test(RefPtr<Expression>&& test) { m_test = move(test); }
  640. void set_update(RefPtr<Expression>&& update) { m_update = move(update); }
  641. void set_body(RefPtr<Statement>&& body) { m_body = move(body); }
  642. const Statement* body() const { return m_body.ptr(); }
  643. private:
  644. RefPtr<VariableDeclaration> m_init;
  645. RefPtr<Expression> m_test;
  646. RefPtr<Expression> m_update;
  647. RefPtr<Statement> m_body;
  648. };
  649. class BlockStatement final : public Statement {
  650. public:
  651. BlockStatement(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  652. : Statement(parent, start, end, filename)
  653. {
  654. }
  655. virtual ~BlockStatement() override = default;
  656. virtual const char* class_name() const override { return "BlockStatement"; }
  657. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  658. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  659. void add_statement(NonnullRefPtr<Statement>&& statement) { m_statements.append(move(statement)); }
  660. private:
  661. NonnullRefPtrVector<Statement> m_statements;
  662. };
  663. class Comment final : public Statement {
  664. public:
  665. Comment(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  666. : Statement(parent, start, end, filename)
  667. {
  668. }
  669. virtual ~Comment() override = default;
  670. virtual const char* class_name() const override { return "Comment"; }
  671. };
  672. class IfStatement : public Statement {
  673. public:
  674. IfStatement(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  675. : Statement(parent, start, end, filename)
  676. {
  677. }
  678. virtual ~IfStatement() override = default;
  679. virtual const char* class_name() const override { return "IfStatement"; }
  680. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  681. virtual NonnullRefPtrVector<Declaration> declarations() const override;
  682. void set_predicate(RefPtr<Expression>&& predicate) { m_predicate = move(predicate); }
  683. void set_then_statement(RefPtr<Statement>&& then) { m_then = move(then); }
  684. void set_else_statement(RefPtr<Statement>&& _else) { m_else = move(_else); }
  685. const Statement* then_statement() const { return m_then.ptr(); }
  686. const Statement* else_statement() const { return m_else.ptr(); }
  687. private:
  688. RefPtr<Expression> m_predicate;
  689. RefPtr<Statement> m_then;
  690. RefPtr<Statement> m_else;
  691. };
  692. class NamespaceDeclaration : public Declaration {
  693. public:
  694. virtual ~NamespaceDeclaration() override = default;
  695. virtual const char* class_name() const override { return "NamespaceDeclaration"; }
  696. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  697. virtual bool is_namespace() const override { return true; }
  698. NamespaceDeclaration(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  699. : Declaration(parent, start, end, filename)
  700. {
  701. }
  702. virtual NonnullRefPtrVector<Declaration> declarations() const override { return m_declarations; }
  703. void add_declaration(NonnullRefPtr<Declaration>&& declaration) { m_declarations.append(move(declaration)); }
  704. private:
  705. NonnullRefPtrVector<Declaration> m_declarations;
  706. };
  707. class CppCastExpression : public Expression {
  708. public:
  709. CppCastExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  710. : Expression(parent, start, end, filename)
  711. {
  712. }
  713. virtual ~CppCastExpression() override = default;
  714. virtual const char* class_name() const override { return "CppCastExpression"; }
  715. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  716. void set_cast_type(StringView cast_type) { m_cast_type = move(cast_type); }
  717. void set_type(NonnullRefPtr<Type>&& type) { m_type = move(type); }
  718. void set_expression(NonnullRefPtr<Expression>&& e) { m_expression = move(e); }
  719. private:
  720. StringView m_cast_type;
  721. RefPtr<Type> m_type;
  722. RefPtr<Expression> m_expression;
  723. };
  724. class CStyleCastExpression : public Expression {
  725. public:
  726. CStyleCastExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  727. : Expression(parent, start, end, filename)
  728. {
  729. }
  730. virtual ~CStyleCastExpression() override = default;
  731. virtual const char* class_name() const override { return "CStyleCastExpression"; }
  732. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  733. void set_type(NonnullRefPtr<Type>&& type) { m_type = move(type); }
  734. void set_expression(NonnullRefPtr<Expression>&& e) { m_expression = move(e); }
  735. private:
  736. RefPtr<Type> m_type;
  737. RefPtr<Expression> m_expression;
  738. };
  739. class SizeofExpression : public Expression {
  740. public:
  741. SizeofExpression(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  742. : Expression(parent, start, end, filename)
  743. {
  744. }
  745. virtual ~SizeofExpression() override = default;
  746. virtual const char* class_name() const override { return "SizeofExpression"; }
  747. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  748. void set_type(RefPtr<Type>&& type) { m_type = move(type); }
  749. private:
  750. RefPtr<Type> m_type;
  751. };
  752. class BracedInitList : public Expression {
  753. public:
  754. BracedInitList(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  755. : Expression(parent, start, end, filename)
  756. {
  757. }
  758. virtual ~BracedInitList() override = default;
  759. virtual const char* class_name() const override { return "BracedInitList"; }
  760. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  761. void add_expression(NonnullRefPtr<Expression>&& exp) { m_expressions.append(move(exp)); }
  762. private:
  763. NonnullRefPtrVector<Expression> m_expressions;
  764. };
  765. class DummyAstNode : public ASTNode {
  766. public:
  767. DummyAstNode(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  768. : ASTNode(parent, start, end, filename)
  769. {
  770. }
  771. virtual bool is_dummy_node() const override { return true; }
  772. virtual const char* class_name() const override { return "DummyAstNode"; }
  773. virtual void dump(FILE* = stdout, size_t = 0) const override { }
  774. };
  775. class Constructor : public FunctionDeclaration {
  776. public:
  777. virtual ~Constructor() override = default;
  778. virtual const char* class_name() const override { return "Constructor"; }
  779. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  780. virtual bool is_constructor() const override { return true; }
  781. Constructor(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  782. : FunctionDeclaration(parent, start, end, filename)
  783. {
  784. }
  785. };
  786. class Destructor : public FunctionDeclaration {
  787. public:
  788. virtual ~Destructor() override = default;
  789. virtual const char* class_name() const override { return "Destructor"; }
  790. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  791. virtual bool is_destructor() const override { return true; }
  792. Destructor(ASTNode* parent, Optional<Position> start, Optional<Position> end, const String& filename)
  793. : FunctionDeclaration(parent, start, end, filename)
  794. {
  795. }
  796. };
  797. template<>
  798. inline bool ASTNode::fast_is<Identifier>() const { return is_identifier(); }
  799. template<>
  800. inline bool ASTNode::fast_is<MemberExpression>() const { return is_member_expression(); }
  801. template<>
  802. inline bool ASTNode::fast_is<VariableOrParameterDeclaration>() const { return is_variable_or_parameter_declaration(); }
  803. template<>
  804. inline bool ASTNode::fast_is<FunctionCall>() const { return is_function_call(); }
  805. template<>
  806. inline bool ASTNode::fast_is<Type>() const { return is_type(); }
  807. template<>
  808. inline bool ASTNode::fast_is<Declaration>() const { return is_declaration(); }
  809. template<>
  810. inline bool ASTNode::fast_is<Name>() const { return is_name(); }
  811. template<>
  812. inline bool ASTNode::fast_is<DummyAstNode>() const { return is_dummy_node(); }
  813. template<>
  814. inline bool ASTNode::fast_is<VariableDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_variable_declaration(); }
  815. template<>
  816. inline bool ASTNode::fast_is<StructOrClassDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_struct_or_class(); }
  817. template<>
  818. inline bool ASTNode::fast_is<FunctionDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_function(); }
  819. template<>
  820. inline bool ASTNode::fast_is<NamespaceDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_namespace(); }
  821. template<>
  822. inline bool ASTNode::fast_is<Constructor>() const { return is_declaration() && verify_cast<Declaration>(*this).is_function() && verify_cast<FunctionDeclaration>(*this).is_constructor(); }
  823. template<>
  824. inline bool ASTNode::fast_is<Destructor>() const { return is_declaration() && verify_cast<Declaration>(*this).is_function() && verify_cast<FunctionDeclaration>(*this).is_destructor(); }
  825. template<>
  826. inline bool ASTNode::fast_is<NamedType>() const { return is_type() && verify_cast<Type>(*this).is_named_type(); }
  827. template<>
  828. inline bool ASTNode::fast_is<TemplatizedName>() const { return is_name() && verify_cast<Name>(*this).is_templatized(); }
  829. }