| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- // 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
- #ifndef CARBON_TOOLCHAIN_CHECK_PATTERN_MATCH_H_
- #define CARBON_TOOLCHAIN_CHECK_PATTERN_MATCH_H_
- #include "toolchain/check/context.h"
- #include "toolchain/sem_ir/function.h"
- #include "toolchain/sem_ir/ids.h"
- namespace Carbon::Check {
- // TODO: Find a better place for this overview, once it has stabilized.
- //
- // The signature pattern of a function call is matched partially by the caller
- // and partially by the callee. `ParamPattern` insts mark the boundary
- // between the two: pattern insts that are descendants of a `ParamPattern`
- // are matched by the callee, and pattern insts that have a `ParamPattern`
- // as a descendant are matched by the caller.
- // Return type for CalleePatternMatch.
- struct CalleePatternMatchResults {
- SemIR::InstBlockId call_param_patterns_id;
- SemIR::InstBlockId call_params_id;
- SemIR::Function::CallParamIndexRanges param_ranges;
- };
- // Emits the pattern-match IR for the declaration of a parameterized entity with
- // the given implicit and explicit parameter patterns, and the given return
- // pattern (any of which may be `None` if not applicable). This IR performs the
- // callee side of pattern matching, starting at the `ParamPattern` insts, and
- // matching them against the corresponding `Call` parameters (see
- // entity_with_params_base.h for the definition of that term).
- // Returns the IDs of inst blocks consisting of references to the `Call`
- // parameter patterns and `Call` parameters of the function, as well as
- // the implicit, explicit, and return index ranges of those blocks.
- auto CalleePatternMatch(Context& context,
- SemIR::InstBlockId implicit_param_patterns_id,
- SemIR::InstBlockId param_patterns_id,
- SemIR::InstId return_pattern_id)
- -> CalleePatternMatchResults;
- // Return type for ThunkPatternMatch.
- struct ThunkPatternMatchResults {
- // The syntactic argument list. If `self_pattern_id` is not `None`, the first
- // element will be the corresponding argument.
- llvm::SmallVector<SemIR::InstId> syntactic_args;
- // The trailing elements of `outer_call_args` that were not used in
- // `syntactic_args`. These presumably represent the output arguments for the
- // return.
- llvm::ArrayRef<SemIR::InstId> ignored_call_args;
- };
- // Given the `Call` arguments for the outer part of a thunked function call,
- // computes the corresponding syntactic argument list, suitable for passing to
- // the inner part of the thunked function call.
- auto ThunkPatternMatch(Context& context, SemIR::InstId self_pattern_id,
- llvm::ArrayRef<SemIR::InstId> param_pattern_ids,
- llvm::ArrayRef<SemIR::InstId> outer_call_args)
- -> ThunkPatternMatchResults;
- // Emits the pattern-match IR for matching the given arguments with the given
- // parameter patterns, and returns an inst block of the arguments that should
- // be passed to the `Call` inst. `is_desugared` indicates that this call
- // was produced by desugaring, not written as a function call in user code, so
- // arguments to `ref` parameters aren't required to have `ref` tags.
- auto CallerPatternMatch(Context& context, SemIR::SpecificId specific_id,
- SemIR::InstId self_pattern_id,
- SemIR::InstBlockId param_patterns_id,
- SemIR::InstId return_pattern_id,
- SemIR::InstId self_arg_id,
- llvm::ArrayRef<SemIR::InstId> arg_refs,
- SemIR::InstId return_arg_id, bool is_desugared)
- -> SemIR::InstBlockId;
- // Emits the pattern-match IR for a local pattern matching operation with the
- // given pattern and scrutinee.
- auto LocalPatternMatch(Context& context, SemIR::InstId pattern_id,
- SemIR::InstId scrutinee_id) -> void;
- } // namespace Carbon::Check
- #endif // CARBON_TOOLCHAIN_CHECK_PATTERN_MATCH_H_
|