// 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 "toolchain/check/context.h" #include "toolchain/check/convert.h" #include "toolchain/sem_ir/node.h" namespace Carbon::Check { auto HandleVariableDeclaration(Context& context, Parse::Node parse_node) -> bool { // Handle the optional initializer. auto init_id = SemIR::NodeId::Invalid; bool has_init = context.parse_tree().node_kind(context.node_stack().PeekParseNode()) != Parse::NodeKind::PatternBinding; if (has_init) { init_id = context.node_stack().PopExpression(); context.node_stack() .PopAndDiscardSoloParseNode(); } // Get the storage and add it to name lookup. SemIR::NodeId var_id = context.node_stack().Pop(); auto var = context.semantics_ir().GetNode(var_id); auto name_id = var.GetAsVarStorage(); context.AddNameToLookup(var.parse_node(), name_id, var_id); // If there was an initializer, assign it to storage. if (has_init) { init_id = Initialize(context, parse_node, var_id, init_id); // TODO: Consider using different node kinds for assignment versus // initialization. context.AddNode(SemIR::Node::Assign::Make(parse_node, var_id, init_id)); } context.node_stack() .PopAndDiscardSoloParseNode(); return true; } auto HandleVariableIntroducer(Context& context, Parse::Node parse_node) -> bool { // No action, just a bracketing node. context.node_stack().Push(parse_node); return true; } auto HandleVariableInitializer(Context& context, Parse::Node parse_node) -> bool { // No action, just a bracketing node. context.node_stack().Push(parse_node); return true; } } // namespace Carbon::Check