Function.cpp 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /*
  2. * Copyright (c) 2023, Dan Klishch <danilklishch@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include "Function.h"
  7. #include "AST/AST.h"
  8. #include "Compiler/ControlFlowGraph.h"
  9. namespace JSSpecCompiler {
  10. TranslationUnit::TranslationUnit(StringView filename)
  11. : m_filename(filename)
  12. {
  13. }
  14. TranslationUnit::~TranslationUnit() = default;
  15. void TranslationUnit::adopt_declaration(NonnullRefPtr<FunctionDeclaration>&& declaration)
  16. {
  17. if (auto decl_name = declaration->declaration(); decl_name.has<AbstractOperationDeclaration>())
  18. m_abstract_operation_index.set(decl_name.get<AbstractOperationDeclaration>().name, declaration.ptr());
  19. m_declarations_owner.append(move(declaration));
  20. }
  21. void TranslationUnit::adopt_function(NonnullRefPtr<FunctionDefinition>&& definition)
  22. {
  23. m_functions_to_compile.append(definition);
  24. adopt_declaration(definition);
  25. }
  26. FunctionDeclarationRef TranslationUnit::find_abstract_operation_by_name(StringView name) const
  27. {
  28. auto it = m_abstract_operation_index.find(name);
  29. if (it == m_abstract_operation_index.end())
  30. return nullptr;
  31. return it->value;
  32. }
  33. EnumeratorRef TranslationUnit::get_node_for_enumerator_value(StringView value)
  34. {
  35. if (auto it = m_enumerator_nodes.find(value); it != m_enumerator_nodes.end())
  36. return it->value;
  37. auto enumerator = NonnullRefPtr(NonnullRefPtr<Enumerator>::Adopt, *new Enumerator { {}, value });
  38. m_enumerator_nodes.set(value, enumerator);
  39. return enumerator;
  40. }
  41. FunctionDeclaration::FunctionDeclaration(Declaration&& declaration, Location location)
  42. : m_declaration(move(declaration))
  43. , m_location(location)
  44. {
  45. }
  46. String FunctionDeclaration::name() const
  47. {
  48. return m_declaration.visit(
  49. [&](AbstractOperationDeclaration const& abstract_operation) {
  50. return abstract_operation.name.to_string();
  51. },
  52. [&](MethodDeclaration const& method) {
  53. return MUST(String::formatted("%{}%", method.name.to_string()));
  54. },
  55. [&](AccessorDeclaration const& accessor) {
  56. return MUST(String::formatted("%get {}%", accessor.name.to_string()));
  57. });
  58. }
  59. ReadonlySpan<FunctionArgument> FunctionDeclaration::arguments() const
  60. {
  61. return m_declaration.visit(
  62. [&](AccessorDeclaration const&) {
  63. return ReadonlySpan<FunctionArgument> {};
  64. },
  65. [&](auto const& declaration) {
  66. return declaration.arguments.span();
  67. });
  68. }
  69. FunctionDefinition::FunctionDefinition(Declaration&& declaration, Location location, Tree ast)
  70. : FunctionDeclaration(move(declaration), location)
  71. , m_ast(move(ast))
  72. , m_named_return_value(make_ref_counted<NamedVariableDeclaration>("$return"sv))
  73. {
  74. }
  75. void FunctionDefinition::reindex_ssa_variables()
  76. {
  77. size_t index = 0;
  78. for (auto const& var : m_local_ssa_variables)
  79. var->m_index = index++;
  80. }
  81. }