interpreter.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. #ifndef EXECUTABLE_SEMANTICS_INTERPRETER_INTERPRETER_H_
  5. #define EXECUTABLE_SEMANTICS_INTERPRETER_INTERPRETER_H_
  6. #include <optional>
  7. #include <utility>
  8. #include <vector>
  9. #include "common/ostream.h"
  10. #include "executable_semantics/ast/ast.h"
  11. #include "executable_semantics/ast/declaration.h"
  12. #include "executable_semantics/ast/expression.h"
  13. #include "executable_semantics/ast/pattern.h"
  14. #include "executable_semantics/interpreter/action.h"
  15. #include "executable_semantics/interpreter/heap.h"
  16. #include "executable_semantics/interpreter/value.h"
  17. #include "llvm/ADT/ArrayRef.h"
  18. namespace Carbon {
  19. // Interprets the program defined by `ast`, allocating values on `arena` and
  20. // printing traces if `trace` is true.
  21. auto InterpProgram(const AST& ast, Nonnull<Arena*> arena, bool trace)
  22. -> ErrorOr<int>;
  23. // Interprets `e` at compile-time, allocating values on `arena` and
  24. // printing traces if `trace` is true. The caller must ensure that all the
  25. // code this evaluates has been typechecked.
  26. auto InterpExp(Nonnull<const Expression*> e, Nonnull<Arena*> arena, bool trace)
  27. -> ErrorOr<Nonnull<const Value*>>;
  28. // Interprets `p` at compile-time, allocating values on `arena` and
  29. // printing traces if `trace` is true. The caller must ensure that all the
  30. // code this evaluates has been typechecked.
  31. auto InterpPattern(Nonnull<const Pattern*> p, Nonnull<Arena*> arena, bool trace)
  32. -> ErrorOr<Nonnull<const Value*>>;
  33. // Attempts to match `v` against the pattern `p`, returning whether matching
  34. // is successful. If it is, populates **bindings with the variables bound by
  35. // the match; `bindings` should only be nullopt in contexts where `p`
  36. // is not permitted to bind variables. **bindings may be modified even if the
  37. // match is unsuccessful, so it should typically be created for the
  38. // PatternMatch call and then merged into an existing scope on success.
  39. // The matches for generic variables in the pattern are output in
  40. // `generic_args`.
  41. // TODO: consider moving this to a separate header.
  42. [[nodiscard]] auto PatternMatch(Nonnull<const Value*> p,
  43. Nonnull<const Value*> v,
  44. SourceLocation source_loc,
  45. std::optional<Nonnull<RuntimeScope*>> bindings,
  46. BindingMap& generic_args) -> bool;
  47. } // namespace Carbon
  48. #endif // EXECUTABLE_SEMANTICS_INTERPRETER_INTERPRETER_H_