| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
- // Exceptions. See /LICENSE for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- #include "executable_semantics/ast/static_scope.h"
- #include "executable_semantics/common/error.h"
- #include "llvm/Support/Error.h"
- namespace Carbon {
- auto StaticScope::Add(std::string name, ValueNodeView entity)
- -> ErrorOr<Success> {
- auto [it, success] = declared_names_.insert({name, entity});
- if (!success && it->second != entity) {
- return FATAL_COMPILATION_ERROR(entity.base().source_loc())
- << "Duplicate name `" << name << "` also found at "
- << it->second.base().source_loc();
- }
- return Success();
- }
- auto StaticScope::Resolve(const std::string& name,
- SourceLocation source_loc) const
- -> ErrorOr<ValueNodeView> {
- ASSIGN_OR_RETURN(std::optional<ValueNodeView> result,
- TryResolve(name, source_loc));
- if (!result) {
- return FATAL_COMPILATION_ERROR(source_loc)
- << "could not resolve '" << name << "'";
- }
- return *result;
- }
- auto StaticScope::TryResolve(const std::string& name,
- SourceLocation source_loc) const
- -> ErrorOr<std::optional<ValueNodeView>> {
- auto it = declared_names_.find(name);
- if (it != declared_names_.end()) {
- return std::make_optional(it->second);
- }
- std::optional<ValueNodeView> result;
- for (Nonnull<const StaticScope*> parent : parent_scopes_) {
- ASSIGN_OR_RETURN(std::optional<ValueNodeView> parent_result,
- parent->TryResolve(name, source_loc));
- if (parent_result.has_value() && result.has_value() &&
- *parent_result != *result) {
- return FATAL_COMPILATION_ERROR(source_loc)
- << "'" << name << "' is ambiguous between "
- << result->base().source_loc() << " and "
- << parent_result->base().source_loc();
- }
- result = parent_result;
- }
- return result;
- }
- } // namespace Carbon
|