// Copyright (c) 2023 PaddlePaddle Authors. All Rights Reserved. // // 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. #pragma once #include "paddle/ir/cast_utils.h" #include "paddle/ir/type_base.h" namespace ir { /// /// \brief Unified interface of the Type class. Derivation of all Type classes /// only derives interfaces, not members. For example, DenseTensorType, /// Float32Type, etc. are all derived classes of Type, but no new member /// variables will be added. /// class Type { public: using Storage = TypeStorage; constexpr Type() = default; Type(const Storage *storage) // NOLINT : storage_(const_cast(storage)) {} Type(const Type &other) = default; Type &operator=(const Type &other) = default; /// /// \brief Some operators are overloaded. /// bool operator==(Type other) const { return storage_ == other.storage_; } bool operator!=(Type other) const { return storage_ != other.storage_; } explicit operator bool() const { return storage_; } bool operator!() const { return storage_ == nullptr; } /// /// \brief Some type attribute acquisition interfaces. /// TypeId type_id() { return storage_->abstract_type().type_id(); } const AbstractType &abstract_type() { return storage_->abstract_type(); } const Storage *storage() const { return storage_; } Dialect &dialect() const { return storage_->abstract_type().dialect(); } IrContext *ir_context() const; /// /// \brief Methods for type judgment and cast. /// static bool classof(Type) { return true; } template bool isa() const { return ir::isa(*this); } template U dyn_cast() const { return ir::dyn_cast(*this); } /// /// \brief Enable hashing Type. /// friend struct std::hash; protected: const Storage *storage_{nullptr}; }; } // namespace ir namespace std { /// /// \brief Enable hashing Type. /// template <> struct hash { std::size_t operator()(const ir::Type &obj) const { return std::hash()(obj.storage_); } }; } // namespace std