// Copyright 2021 The Tint Authors. // // Licensed under the Apache License, Version 2.0(the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef SRC_SEM_FUNCTION_H_ #define SRC_SEM_FUNCTION_H_ #include #include #include "src/ast/variable.h" #include "src/sem/call_target.h" namespace tint { // Forward declarations namespace ast { class BindingDecoration; class BuiltinDecoration; class Function; class GroupDecoration; class LocationDecoration; class ReturnStatement; } // namespace ast namespace sem { class Variable; /// Function holds the semantic information for function nodes. class Function : public Castable { public: /// A vector of [Variable*, ast::Variable::BindingPoint] pairs using VariableBindings = std::vector>; /// Constructor /// @param declaration the ast::Function /// @param parameters the parameters to the function /// @param referenced_module_vars the referenced module variables /// @param local_referenced_module_vars the locally referenced module /// @param return_statements the function return statements /// variables /// @param ancestor_entry_points the ancestor entry points Function(ast::Function* declaration, std::vector parameters, std::vector referenced_module_vars, std::vector local_referenced_module_vars, std::vector return_statements, std::vector ancestor_entry_points); /// Destructor ~Function() override; /// @returns the ast::Function declaration ast::Function* Declaration() const { return declaration_; } /// @return the parameters to the function const std::vector Parameters() const { return parameters_; } /// Note: If this function calls other functions, the return will also include /// all of the referenced variables from the callees. /// @returns the referenced module variables const std::vector& ReferencedModuleVariables() const { return referenced_module_vars_; } /// @returns the locally referenced module variables const std::vector& LocalReferencedModuleVariables() const { return local_referenced_module_vars_; } /// @returns the return statements const std::vector ReturnStatements() const { return return_statements_; } /// @returns the ancestor entry points const std::vector& AncestorEntryPoints() const { return ancestor_entry_points_; } /// Retrieves any referenced location variables /// @returns the pair. std::vector> ReferencedLocationVariables() const; /// Retrieves any referenced builtin variables /// @returns the pair. std::vector> ReferencedBuiltinVariables() const; /// Retrieves any referenced uniform variables. Note, the variables must be /// decorated with both binding and group decorations. /// @returns the referenced uniforms VariableBindings ReferencedUniformVariables() const; /// Retrieves any referenced storagebuffer variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced storagebuffers VariableBindings ReferencedStorageBufferVariables() const; /// Retrieves any referenced regular Sampler variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced storagebuffers VariableBindings ReferencedSamplerVariables() const; /// Retrieves any referenced comparison Sampler variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced storagebuffers VariableBindings ReferencedComparisonSamplerVariables() const; /// Retrieves any referenced sampled textures variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced sampled textures VariableBindings ReferencedSampledTextureVariables() const; /// Retrieves any referenced multisampled textures variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced sampled textures VariableBindings ReferencedMultisampledTextureVariables() const; /// Retrieves any referenced storage texture variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced storage textures VariableBindings ReferencedStorageTextureVariables() const; /// Retrieves any referenced depth texture variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced storage textures VariableBindings ReferencedDepthTextureVariables() const; /// Checks if the given entry point is an ancestor /// @param sym the entry point symbol /// @returns true if `sym` is an ancestor entry point of this function bool HasAncestorEntryPoint(Symbol sym) const; private: VariableBindings ReferencedSamplerVariablesImpl(type::SamplerKind kind) const; VariableBindings ReferencedSampledTextureVariablesImpl( bool multisampled) const; ast::Function* const declaration_; std::vector const parameters_; std::vector const referenced_module_vars_; std::vector const local_referenced_module_vars_; std::vector const return_statements_; std::vector const ancestor_entry_points_; }; } // namespace sem } // namespace tint #endif // SRC_SEM_FUNCTION_H_