AST.h 39 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067
  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/ByteString.h>
  8. #include <AK/DeprecatedFlyString.h>
  9. #include <AK/Optional.h>
  10. #include <AK/RefCounted.h>
  11. #include <AK/StringView.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 StringView 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 const* 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. DeprecatedFlyString const& filename() const
  43. {
  44. return m_filename;
  45. }
  46. void set_end(Position const& end) { m_end = end; }
  47. void set_parent(ASTNode const& parent) { m_parent = &parent; }
  48. virtual Vector<NonnullRefPtr<Declaration const>> 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 const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  59. : m_parent(parent)
  60. , m_start(start)
  61. , m_end(end)
  62. , m_filename(filename)
  63. {
  64. }
  65. private:
  66. ASTNode const* m_parent { nullptr };
  67. Optional<Position> m_start;
  68. Optional<Position> m_end;
  69. DeprecatedFlyString m_filename;
  70. };
  71. class TranslationUnit : public ASTNode {
  72. public:
  73. virtual ~TranslationUnit() override = default;
  74. virtual StringView class_name() const override { return "TranslationUnit"sv; }
  75. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  76. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override { return m_declarations; }
  77. TranslationUnit(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  78. : ASTNode(parent, start, end, filename)
  79. {
  80. }
  81. void set_declarations(Vector<NonnullRefPtr<Declaration const>>&& declarations) { m_declarations = move(declarations); }
  82. private:
  83. Vector<NonnullRefPtr<Declaration const>> m_declarations;
  84. };
  85. class Statement : public ASTNode {
  86. public:
  87. virtual ~Statement() override = default;
  88. virtual StringView class_name() const override { return "Statement"sv; }
  89. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  90. protected:
  91. Statement(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& 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. Name const* name() const { return m_name; }
  109. StringView full_name() const;
  110. void set_name(RefPtr<Name const> name) { m_name = move(name); }
  111. protected:
  112. Declaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  113. : Statement(parent, start, end, filename)
  114. {
  115. }
  116. RefPtr<Name const> m_name;
  117. mutable Optional<ByteString> m_full_name;
  118. };
  119. class InvalidDeclaration : public Declaration {
  120. public:
  121. virtual ~InvalidDeclaration() override = default;
  122. virtual StringView class_name() const override { return "InvalidDeclaration"sv; }
  123. InvalidDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  124. : Declaration(parent, start, end, filename)
  125. {
  126. }
  127. };
  128. class FunctionDeclaration : public Declaration {
  129. public:
  130. virtual ~FunctionDeclaration() override = default;
  131. virtual StringView class_name() const override { return "FunctionDeclaration"sv; }
  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 const> definition() { return m_definition; }
  137. FunctionDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  138. : Declaration(parent, start, end, filename)
  139. {
  140. }
  141. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  142. Vector<StringView> const& qualifiers() const { return m_qualifiers; }
  143. void set_qualifiers(Vector<StringView> const& qualifiers) { m_qualifiers = qualifiers; }
  144. Type const* return_type() const { return m_return_type.ptr(); }
  145. void set_return_type(RefPtr<Type const> const& return_type) { m_return_type = return_type; }
  146. Vector<NonnullRefPtr<Parameter const>> const& parameters() const { return m_parameters; }
  147. void set_parameters(Vector<NonnullRefPtr<Parameter const>> const& parameters) { m_parameters = parameters; }
  148. FunctionDefinition const* definition() const { return m_definition.ptr(); }
  149. void set_definition(RefPtr<FunctionDefinition const>&& definition) { m_definition = move(definition); }
  150. private:
  151. Vector<StringView> m_qualifiers;
  152. RefPtr<Type const> m_return_type;
  153. Vector<NonnullRefPtr<Parameter const>> m_parameters;
  154. RefPtr<FunctionDefinition const> 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 const>&& type) { m_type = move(type); }
  161. Type const* type() const { return m_type.ptr(); }
  162. protected:
  163. VariableOrParameterDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  164. : Declaration(parent, start, end, filename)
  165. {
  166. }
  167. RefPtr<Type const> m_type;
  168. };
  169. class Parameter : public VariableOrParameterDeclaration {
  170. public:
  171. virtual ~Parameter() override = default;
  172. virtual StringView class_name() const override { return "Parameter"sv; }
  173. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  174. virtual bool is_parameter() const override { return true; }
  175. Parameter(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename, RefPtr<Name const> 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 StringView class_name() const override { return "Type"sv; }
  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 ByteString to_byte_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 const* parent, Optional<Position> start, Optional<Position> end, ByteString const& 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 StringView class_name() const override { return "NamedType"sv; }
  211. virtual ByteString to_byte_string() const override;
  212. virtual bool is_named_type() const override { return true; }
  213. NamedType(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  214. : Type(parent, start, end, filename)
  215. {
  216. }
  217. Name const* name() const { return m_name.ptr(); }
  218. void set_name(RefPtr<Name const>&& name) { m_name = move(name); }
  219. private:
  220. RefPtr<Name const> m_name;
  221. };
  222. class Pointer : public Type {
  223. public:
  224. virtual ~Pointer() override = default;
  225. virtual StringView class_name() const override { return "Pointer"sv; }
  226. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  227. virtual ByteString to_byte_string() const override;
  228. Pointer(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  229. : Type(parent, start, end, filename)
  230. {
  231. }
  232. Type const* pointee() const { return m_pointee.ptr(); }
  233. void set_pointee(RefPtr<Type const>&& pointee) { m_pointee = move(pointee); }
  234. private:
  235. RefPtr<Type const> m_pointee;
  236. };
  237. class Reference : public Type {
  238. public:
  239. virtual ~Reference() override = default;
  240. virtual StringView class_name() const override { return "Reference"sv; }
  241. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  242. virtual ByteString to_byte_string() const override;
  243. enum class Kind {
  244. Lvalue,
  245. Rvalue,
  246. };
  247. Reference(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename, Kind kind)
  248. : Type(parent, start, end, filename)
  249. , m_kind(kind)
  250. {
  251. }
  252. Type const* referenced_type() const { return m_referenced_type.ptr(); }
  253. void set_referenced_type(RefPtr<Type const>&& 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 StringView class_name() const override { return "FunctionType"sv; }
  263. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  264. virtual ByteString to_byte_string() const override;
  265. FunctionType(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  266. : Type(parent, start, end, filename)
  267. {
  268. }
  269. void set_return_type(Type& type) { m_return_type = type; }
  270. void set_parameters(Vector<NonnullRefPtr<Parameter const>> parameters) { m_parameters = move(parameters); }
  271. private:
  272. RefPtr<Type const> m_return_type;
  273. Vector<NonnullRefPtr<Parameter const>> m_parameters;
  274. };
  275. class FunctionDefinition : public ASTNode {
  276. public:
  277. virtual ~FunctionDefinition() override = default;
  278. virtual StringView class_name() const override { return "FunctionDefinition"sv; }
  279. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  280. FunctionDefinition(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  281. : ASTNode(parent, start, end, filename)
  282. {
  283. }
  284. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  285. Vector<NonnullRefPtr<Statement const>> const& statements() const { return m_statements; }
  286. void add_statement(NonnullRefPtr<Statement const>&& statement) { m_statements.append(move(statement)); }
  287. private:
  288. Vector<NonnullRefPtr<Statement const>> m_statements;
  289. };
  290. class InvalidStatement : public Statement {
  291. public:
  292. virtual ~InvalidStatement() override = default;
  293. virtual StringView class_name() const override { return "InvalidStatement"sv; }
  294. InvalidStatement(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  295. : Statement(parent, start, end, filename)
  296. {
  297. }
  298. };
  299. class Expression : public Statement {
  300. public:
  301. virtual ~Expression() override = default;
  302. virtual StringView class_name() const override { return "Expression"sv; }
  303. protected:
  304. Expression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  305. : Statement(parent, start, end, filename)
  306. {
  307. }
  308. };
  309. class InvalidExpression : public Expression {
  310. public:
  311. virtual ~InvalidExpression() override = default;
  312. virtual StringView class_name() const override { return "InvalidExpression"sv; }
  313. InvalidExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  314. : Expression(parent, start, end, filename)
  315. {
  316. }
  317. };
  318. class VariableDeclaration : public VariableOrParameterDeclaration {
  319. public:
  320. virtual ~VariableDeclaration() override = default;
  321. virtual StringView class_name() const override { return "VariableDeclaration"sv; }
  322. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  323. VariableDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  324. : VariableOrParameterDeclaration(parent, start, end, filename)
  325. {
  326. }
  327. virtual bool is_variable_declaration() const override { return true; }
  328. Expression const* initial_value() const { return m_initial_value; }
  329. void set_initial_value(RefPtr<Expression const>&& initial_value) { m_initial_value = move(initial_value); }
  330. private:
  331. RefPtr<Expression const> m_initial_value;
  332. };
  333. class Identifier : public Expression {
  334. public:
  335. virtual ~Identifier() override = default;
  336. virtual StringView class_name() const override { return "Identifier"sv; }
  337. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  338. Identifier(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename, StringView name)
  339. : Expression(parent, start, end, filename)
  340. , m_name(name)
  341. {
  342. }
  343. Identifier(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& 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 StringView class_name() const override { return "Name"sv; }
  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. virtual bool is_sized() const { return false; }
  361. Name(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  362. : Expression(parent, start, end, filename)
  363. {
  364. }
  365. virtual StringView full_name() const;
  366. Identifier const* name() const { return m_name.ptr(); }
  367. void set_name(RefPtr<Identifier const>&& name) { m_name = move(name); }
  368. Vector<NonnullRefPtr<Identifier const>> const& scope() const { return m_scope; }
  369. void set_scope(Vector<NonnullRefPtr<Identifier const>> scope) { m_scope = move(scope); }
  370. void add_to_scope(NonnullRefPtr<Identifier const>&& part) { m_scope.append(move(part)); }
  371. private:
  372. RefPtr<Identifier const> m_name;
  373. Vector<NonnullRefPtr<Identifier const>> m_scope;
  374. mutable Optional<ByteString> m_full_name;
  375. };
  376. class SizedName : public Name {
  377. public:
  378. virtual ~SizedName() override = default;
  379. virtual StringView class_name() const override { return "SizedName"sv; }
  380. virtual bool is_sized() const override { return true; }
  381. void dump(FILE* output, size_t indent) const override;
  382. SizedName(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  383. : Name(parent, start, end, filename)
  384. {
  385. }
  386. void append_dimension(StringView dim) { m_dimensions.append(dim); }
  387. private:
  388. Vector<StringView> m_dimensions;
  389. mutable Optional<ByteString> m_full_name;
  390. };
  391. class TemplatizedName : public Name {
  392. public:
  393. virtual ~TemplatizedName() override = default;
  394. virtual StringView class_name() const override { return "TemplatizedName"sv; }
  395. virtual bool is_templatized() const override { return true; }
  396. virtual StringView full_name() const override;
  397. TemplatizedName(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  398. : Name(parent, start, end, filename)
  399. {
  400. }
  401. void add_template_argument(NonnullRefPtr<Type const>&& type) { m_template_arguments.append(move(type)); }
  402. private:
  403. Vector<NonnullRefPtr<Type const>> m_template_arguments;
  404. mutable Optional<ByteString> m_full_name;
  405. };
  406. class NumericLiteral : public Expression {
  407. public:
  408. virtual ~NumericLiteral() override = default;
  409. virtual StringView class_name() const override { return "NumericLiteral"sv; }
  410. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  411. NumericLiteral(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename, StringView value)
  412. : Expression(parent, start, end, filename)
  413. , m_value(value)
  414. {
  415. }
  416. StringView value() const { return m_value; }
  417. private:
  418. StringView m_value;
  419. };
  420. class NullPointerLiteral : public Expression {
  421. public:
  422. virtual ~NullPointerLiteral() override = default;
  423. virtual StringView class_name() const override { return "NullPointerLiteral"sv; }
  424. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  425. NullPointerLiteral(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  426. : Expression(parent, start, end, filename)
  427. {
  428. }
  429. };
  430. class BooleanLiteral : public Expression {
  431. public:
  432. virtual ~BooleanLiteral() override = default;
  433. virtual StringView class_name() const override { return "BooleanLiteral"sv; }
  434. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  435. BooleanLiteral(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename, bool value)
  436. : Expression(parent, start, end, filename)
  437. , m_value(value)
  438. {
  439. }
  440. private:
  441. bool m_value;
  442. };
  443. enum class BinaryOp {
  444. Addition,
  445. Subtraction,
  446. Multiplication,
  447. Division,
  448. Modulo,
  449. GreaterThan,
  450. GreaterThanEquals,
  451. LessThan,
  452. LessThanEquals,
  453. BitwiseAnd,
  454. BitwiseOr,
  455. BitwiseXor,
  456. LeftShift,
  457. RightShift,
  458. EqualsEquals,
  459. NotEqual,
  460. LogicalOr,
  461. LogicalAnd,
  462. Arrow,
  463. };
  464. class BinaryExpression : public Expression {
  465. public:
  466. BinaryExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  467. : Expression(parent, start, end, filename)
  468. {
  469. }
  470. virtual ~BinaryExpression() override = default;
  471. virtual StringView class_name() const override { return "BinaryExpression"sv; }
  472. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  473. BinaryOp op() const { return m_op; }
  474. void set_op(BinaryOp op) { m_op = op; }
  475. Expression const* lhs() const { return m_lhs.ptr(); }
  476. void set_lhs(RefPtr<Expression const>&& e) { m_lhs = move(e); }
  477. Expression const* rhs() const { return m_rhs.ptr(); }
  478. void set_rhs(RefPtr<Expression const>&& e) { m_rhs = move(e); }
  479. private:
  480. BinaryOp m_op;
  481. RefPtr<Expression const> m_lhs;
  482. RefPtr<Expression const> m_rhs;
  483. };
  484. enum class AssignmentOp {
  485. Assignment,
  486. AdditionAssignment,
  487. SubtractionAssignment,
  488. };
  489. class AssignmentExpression : public Expression {
  490. public:
  491. AssignmentExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  492. : Expression(parent, start, end, filename)
  493. {
  494. }
  495. virtual ~AssignmentExpression() override = default;
  496. virtual StringView class_name() const override { return "AssignmentExpression"sv; }
  497. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  498. AssignmentOp op() const { return m_op; }
  499. void set_op(AssignmentOp op) { m_op = op; }
  500. Expression const* lhs() const { return m_lhs; }
  501. void set_lhs(RefPtr<Expression const>&& e) { m_lhs = move(e); }
  502. Expression const* rhs() const { return m_rhs; }
  503. void set_rhs(RefPtr<Expression const>&& e) { m_rhs = move(e); }
  504. private:
  505. AssignmentOp m_op {};
  506. RefPtr<Expression const> m_lhs;
  507. RefPtr<Expression const> m_rhs;
  508. };
  509. class FunctionCall : public Expression {
  510. public:
  511. FunctionCall(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  512. : Expression(parent, start, end, filename)
  513. {
  514. }
  515. virtual ~FunctionCall() override = default;
  516. virtual StringView class_name() const override { return "FunctionCall"sv; }
  517. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  518. virtual bool is_function_call() const override { return true; }
  519. Expression const* callee() const { return m_callee.ptr(); }
  520. void set_callee(RefPtr<Expression const>&& callee) { m_callee = move(callee); }
  521. void add_argument(NonnullRefPtr<Expression const>&& arg) { m_arguments.append(move(arg)); }
  522. Vector<NonnullRefPtr<Expression const>> const& arguments() const { return m_arguments; }
  523. private:
  524. RefPtr<Expression const> m_callee;
  525. Vector<NonnullRefPtr<Expression const>> m_arguments;
  526. };
  527. class StringLiteral final : public Expression {
  528. public:
  529. StringLiteral(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  530. : Expression(parent, start, end, filename)
  531. {
  532. }
  533. ~StringLiteral() override = default;
  534. virtual StringView class_name() const override { return "StringLiteral"sv; }
  535. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  536. ByteString const& value() const { return m_value; }
  537. void set_value(ByteString value) { m_value = move(value); }
  538. private:
  539. ByteString m_value;
  540. };
  541. class ReturnStatement : public Statement {
  542. public:
  543. virtual ~ReturnStatement() override = default;
  544. virtual StringView class_name() const override { return "ReturnStatement"sv; }
  545. ReturnStatement(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  546. : Statement(parent, start, end, filename)
  547. {
  548. }
  549. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  550. Expression const* value() const { return m_value.ptr(); }
  551. void set_value(RefPtr<Expression const>&& value) { m_value = move(value); }
  552. private:
  553. RefPtr<Expression const> m_value;
  554. };
  555. class EnumDeclaration : public Declaration {
  556. public:
  557. virtual ~EnumDeclaration() override = default;
  558. virtual StringView class_name() const override { return "EnumDeclaration"sv; }
  559. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  560. virtual bool is_enum() const override { return true; }
  561. EnumDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  562. : Declaration(parent, start, end, filename)
  563. {
  564. }
  565. enum class Type {
  566. RegularEnum,
  567. EnumClass
  568. };
  569. void set_type(Type type) { m_type = type; }
  570. void add_entry(StringView entry, RefPtr<Expression const> value = nullptr) { m_entries.append({ entry, move(value) }); }
  571. private:
  572. Type m_type { Type::RegularEnum };
  573. struct EnumerationEntry {
  574. StringView name;
  575. RefPtr<Expression const> value;
  576. };
  577. Vector<EnumerationEntry> m_entries;
  578. };
  579. class StructOrClassDeclaration : public Declaration {
  580. public:
  581. virtual ~StructOrClassDeclaration() override = default;
  582. virtual StringView class_name() const override { return "StructOrClassDeclaration"sv; }
  583. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  584. virtual bool is_struct_or_class() const override { return true; }
  585. virtual bool is_struct() const override { return m_type == Type::Struct; }
  586. virtual bool is_class() const override { return m_type == Type::Class; }
  587. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  588. enum class Type {
  589. Struct,
  590. Class
  591. };
  592. StructOrClassDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename, StructOrClassDeclaration::Type type)
  593. : Declaration(parent, start, end, filename)
  594. , m_type(type)
  595. {
  596. }
  597. Vector<NonnullRefPtr<Declaration const>> const& members() const { return m_members; }
  598. void set_members(Vector<NonnullRefPtr<Declaration const>>&& members) { m_members = move(members); }
  599. Vector<NonnullRefPtr<Name const>> const& baseclasses() const { return m_baseclasses; }
  600. void set_baseclasses(Vector<NonnullRefPtr<Name const>>&& baseclasses) { m_baseclasses = move(baseclasses); }
  601. private:
  602. StructOrClassDeclaration::Type m_type;
  603. Vector<NonnullRefPtr<Declaration const>> m_members;
  604. Vector<NonnullRefPtr<Name const>> m_baseclasses;
  605. };
  606. enum class UnaryOp {
  607. Invalid,
  608. BitwiseNot,
  609. Not,
  610. Plus,
  611. Minus,
  612. PlusPlus,
  613. Address,
  614. };
  615. class UnaryExpression : public Expression {
  616. public:
  617. UnaryExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  618. : Expression(parent, start, end, filename)
  619. {
  620. }
  621. virtual ~UnaryExpression() override = default;
  622. virtual StringView class_name() const override { return "UnaryExpression"sv; }
  623. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  624. void set_op(UnaryOp op) { m_op = op; }
  625. void set_lhs(RefPtr<Expression const>&& e) { m_lhs = move(e); }
  626. private:
  627. UnaryOp m_op;
  628. RefPtr<Expression const> m_lhs;
  629. };
  630. class MemberExpression : public Expression {
  631. public:
  632. MemberExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  633. : Expression(parent, start, end, filename)
  634. {
  635. }
  636. virtual ~MemberExpression() override = default;
  637. virtual StringView class_name() const override { return "MemberExpression"sv; }
  638. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  639. virtual bool is_member_expression() const override { return true; }
  640. Expression const* object() const { return m_object.ptr(); }
  641. void set_object(RefPtr<Expression const>&& object) { m_object = move(object); }
  642. Expression const* property() const { return m_property.ptr(); }
  643. void set_property(RefPtr<Expression const>&& property) { m_property = move(property); }
  644. private:
  645. RefPtr<Expression const> m_object;
  646. RefPtr<Expression const> m_property;
  647. };
  648. class ForStatement : public Statement {
  649. public:
  650. ForStatement(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  651. : Statement(parent, start, end, filename)
  652. {
  653. }
  654. virtual ~ForStatement() override = default;
  655. virtual StringView class_name() const override { return "ForStatement"sv; }
  656. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  657. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  658. void set_init(RefPtr<VariableDeclaration const>&& init) { m_init = move(init); }
  659. void set_test(RefPtr<Expression const>&& test) { m_test = move(test); }
  660. void set_update(RefPtr<Expression const>&& update) { m_update = move(update); }
  661. void set_body(RefPtr<Statement const>&& body) { m_body = move(body); }
  662. Statement const* body() const { return m_body.ptr(); }
  663. private:
  664. RefPtr<VariableDeclaration const> m_init;
  665. RefPtr<Expression const> m_test;
  666. RefPtr<Expression const> m_update;
  667. RefPtr<Statement const> m_body;
  668. };
  669. class BlockStatement final : public Statement {
  670. public:
  671. BlockStatement(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  672. : Statement(parent, start, end, filename)
  673. {
  674. }
  675. virtual ~BlockStatement() override = default;
  676. virtual StringView class_name() const override { return "BlockStatement"sv; }
  677. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  678. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  679. void add_statement(NonnullRefPtr<Statement const>&& statement) { m_statements.append(move(statement)); }
  680. Vector<NonnullRefPtr<Statement const>> const& statements() const { return m_statements; }
  681. private:
  682. Vector<NonnullRefPtr<Statement const>> m_statements;
  683. };
  684. class Comment final : public Statement {
  685. public:
  686. Comment(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  687. : Statement(parent, start, end, filename)
  688. {
  689. }
  690. virtual ~Comment() override = default;
  691. virtual StringView class_name() const override { return "Comment"sv; }
  692. };
  693. class IfStatement : public Statement {
  694. public:
  695. IfStatement(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  696. : Statement(parent, start, end, filename)
  697. {
  698. }
  699. virtual ~IfStatement() override = default;
  700. virtual StringView class_name() const override { return "IfStatement"sv; }
  701. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  702. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override;
  703. void set_predicate(RefPtr<Expression const>&& predicate) { m_predicate = move(predicate); }
  704. void set_then_statement(RefPtr<Statement const>&& then) { m_then = move(then); }
  705. void set_else_statement(RefPtr<Statement const>&& _else) { m_else = move(_else); }
  706. Expression const* predicate() const { return m_predicate.ptr(); }
  707. Statement const* then_statement() const { return m_then.ptr(); }
  708. Statement const* else_statement() const { return m_else.ptr(); }
  709. private:
  710. RefPtr<Expression const> m_predicate;
  711. RefPtr<Statement const> m_then;
  712. RefPtr<Statement const> m_else;
  713. };
  714. class NamespaceDeclaration : public Declaration {
  715. public:
  716. virtual ~NamespaceDeclaration() override = default;
  717. virtual StringView class_name() const override { return "NamespaceDeclaration"sv; }
  718. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  719. virtual bool is_namespace() const override { return true; }
  720. NamespaceDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  721. : Declaration(parent, start, end, filename)
  722. {
  723. }
  724. virtual Vector<NonnullRefPtr<Declaration const>> declarations() const override { return m_declarations; }
  725. void add_declaration(NonnullRefPtr<Declaration const>&& declaration) { m_declarations.append(move(declaration)); }
  726. private:
  727. Vector<NonnullRefPtr<Declaration const>> m_declarations;
  728. };
  729. class CppCastExpression : public Expression {
  730. public:
  731. CppCastExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  732. : Expression(parent, start, end, filename)
  733. {
  734. }
  735. virtual ~CppCastExpression() override = default;
  736. virtual StringView class_name() const override { return "CppCastExpression"sv; }
  737. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  738. void set_cast_type(StringView cast_type) { m_cast_type = move(cast_type); }
  739. void set_type(NonnullRefPtr<Type const>&& type) { m_type = move(type); }
  740. void set_expression(NonnullRefPtr<Expression const>&& e) { m_expression = move(e); }
  741. private:
  742. StringView m_cast_type;
  743. RefPtr<Type const> m_type;
  744. RefPtr<Expression const> m_expression;
  745. };
  746. class CStyleCastExpression : public Expression {
  747. public:
  748. CStyleCastExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  749. : Expression(parent, start, end, filename)
  750. {
  751. }
  752. virtual ~CStyleCastExpression() override = default;
  753. virtual StringView class_name() const override { return "CStyleCastExpression"sv; }
  754. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  755. void set_type(NonnullRefPtr<Type const>&& type) { m_type = move(type); }
  756. void set_expression(NonnullRefPtr<Expression const>&& e) { m_expression = move(e); }
  757. private:
  758. RefPtr<Type const> m_type;
  759. RefPtr<Expression const> m_expression;
  760. };
  761. class SizeofExpression : public Expression {
  762. public:
  763. SizeofExpression(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  764. : Expression(parent, start, end, filename)
  765. {
  766. }
  767. virtual ~SizeofExpression() override = default;
  768. virtual StringView class_name() const override { return "SizeofExpression"sv; }
  769. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  770. void set_type(RefPtr<Type const>&& type) { m_type = move(type); }
  771. private:
  772. RefPtr<Type const> m_type;
  773. };
  774. class BracedInitList : public Expression {
  775. public:
  776. BracedInitList(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  777. : Expression(parent, start, end, filename)
  778. {
  779. }
  780. virtual ~BracedInitList() override = default;
  781. virtual StringView class_name() const override { return "BracedInitList"sv; }
  782. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  783. void add_expression(NonnullRefPtr<Expression const>&& exp) { m_expressions.append(move(exp)); }
  784. private:
  785. Vector<NonnullRefPtr<Expression const>> m_expressions;
  786. };
  787. class DummyAstNode : public ASTNode {
  788. public:
  789. DummyAstNode(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  790. : ASTNode(parent, start, end, filename)
  791. {
  792. }
  793. virtual bool is_dummy_node() const override { return true; }
  794. virtual StringView class_name() const override { return "DummyAstNode"sv; }
  795. virtual void dump(FILE* = stdout, size_t = 0) const override { }
  796. };
  797. class Constructor : public FunctionDeclaration {
  798. public:
  799. virtual ~Constructor() override = default;
  800. virtual StringView class_name() const override { return "Constructor"sv; }
  801. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  802. virtual bool is_constructor() const override { return true; }
  803. Constructor(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  804. : FunctionDeclaration(parent, start, end, filename)
  805. {
  806. }
  807. };
  808. class Destructor : public FunctionDeclaration {
  809. public:
  810. virtual ~Destructor() override = default;
  811. virtual StringView class_name() const override { return "Destructor"sv; }
  812. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  813. virtual bool is_destructor() const override { return true; }
  814. Destructor(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  815. : FunctionDeclaration(parent, start, end, filename)
  816. {
  817. }
  818. };
  819. class UsingNamespaceDeclaration : public Declaration {
  820. public:
  821. virtual ~UsingNamespaceDeclaration() override = default;
  822. virtual StringView class_name() const override { return "UsingNamespaceDeclaration"sv; }
  823. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  824. UsingNamespaceDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  825. : Declaration(parent, start, end, filename)
  826. {
  827. }
  828. };
  829. class TypedefDeclaration : public Declaration {
  830. public:
  831. virtual ~TypedefDeclaration() override = default;
  832. virtual StringView class_name() const override { return "TypedefDeclaration"sv; }
  833. virtual void dump(FILE* = stdout, size_t indent = 0) const override;
  834. TypedefDeclaration(ASTNode const* parent, Optional<Position> start, Optional<Position> end, ByteString const& filename)
  835. : Declaration(parent, start, end, filename)
  836. {
  837. }
  838. void set_alias(Type const& alias) { m_alias = alias; }
  839. Type const* alias() const { return m_alias.ptr(); }
  840. private:
  841. RefPtr<Type const> m_alias;
  842. };
  843. template<>
  844. inline bool ASTNode::fast_is<Identifier>() const { return is_identifier(); }
  845. template<>
  846. inline bool ASTNode::fast_is<MemberExpression>() const { return is_member_expression(); }
  847. template<>
  848. inline bool ASTNode::fast_is<VariableOrParameterDeclaration>() const { return is_variable_or_parameter_declaration(); }
  849. template<>
  850. inline bool ASTNode::fast_is<FunctionCall>() const { return is_function_call(); }
  851. template<>
  852. inline bool ASTNode::fast_is<Type>() const { return is_type(); }
  853. template<>
  854. inline bool ASTNode::fast_is<Declaration>() const { return is_declaration(); }
  855. template<>
  856. inline bool ASTNode::fast_is<Name>() const { return is_name(); }
  857. template<>
  858. inline bool ASTNode::fast_is<DummyAstNode>() const { return is_dummy_node(); }
  859. template<>
  860. inline bool ASTNode::fast_is<VariableDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_variable_declaration(); }
  861. template<>
  862. inline bool ASTNode::fast_is<StructOrClassDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_struct_or_class(); }
  863. template<>
  864. inline bool ASTNode::fast_is<FunctionDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_function(); }
  865. template<>
  866. inline bool ASTNode::fast_is<NamespaceDeclaration>() const { return is_declaration() && verify_cast<Declaration>(*this).is_namespace(); }
  867. template<>
  868. inline bool ASTNode::fast_is<Constructor>() const { return is_declaration() && verify_cast<Declaration>(*this).is_function() && verify_cast<FunctionDeclaration>(*this).is_constructor(); }
  869. template<>
  870. inline bool ASTNode::fast_is<Destructor>() const { return is_declaration() && verify_cast<Declaration>(*this).is_function() && verify_cast<FunctionDeclaration>(*this).is_destructor(); }
  871. template<>
  872. inline bool ASTNode::fast_is<NamedType>() const { return is_type() && verify_cast<Type>(*this).is_named_type(); }
  873. template<>
  874. inline bool ASTNode::fast_is<TemplatizedName>() const { return is_name() && verify_cast<Name>(*this).is_templatized(); }
  875. template<>
  876. inline bool ASTNode::fast_is<SizedName>() const { return is_name() && verify_cast<Name>(*this).is_sized(); }
  877. }