ReferenceResolvingPass.cpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2023, Dan Klishch <danilklishch@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <AK/HashMap.h>
  7. #include "AST/AST.h"
  8. #include "Compiler/Passes/ReferenceResolvingPass.h"
  9. #include "Function.h"
  10. namespace JSSpecCompiler {
  11. RecursionDecision ReferenceResolvingPass::on_entry(Tree tree)
  12. {
  13. if (auto binary_operation = as<BinaryOperation>(tree); binary_operation) {
  14. if (binary_operation->m_operation != BinaryOperator::Declaration)
  15. return RecursionDecision::Recurse;
  16. binary_operation->m_operation = BinaryOperator::Assignment;
  17. if (auto variable_name = as<UnresolvedReference>(binary_operation->m_left); variable_name) {
  18. auto name = variable_name->m_name;
  19. if (!m_function->m_local_variables.contains(name))
  20. m_function->m_local_variables.set(name, make_ref_counted<NamedVariableDeclaration>(name));
  21. }
  22. }
  23. return RecursionDecision::Recurse;
  24. }
  25. void ReferenceResolvingPass::on_leave(Tree tree)
  26. {
  27. auto& functions = m_function->m_translation_unit->function_index;
  28. if (auto reference = as<UnresolvedReference>(tree); reference) {
  29. auto name = reference->m_name;
  30. if (name.starts_with("[["sv) && name.ends_with("]]"sv)) {
  31. replace_current_node_with(make_ref_counted<SlotName>(name.substring_view(2, name.length() - 4)));
  32. return;
  33. }
  34. if (auto it = m_function->m_local_variables.find(name); it != m_function->m_local_variables.end()) {
  35. replace_current_node_with(make_ref_counted<Variable>(it->value));
  36. return;
  37. }
  38. if (auto it = functions.find(name); it != functions.end()) {
  39. replace_current_node_with(it->value);
  40. return;
  41. }
  42. }
  43. }
  44. }