// Copyright (c) 2016-2018 Kiwano - Nomango // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. #pragma once #include #include #include #include #include #include namespace kiwano { KGE_DECLARE_SMART_PTR(ObjectBase); /** * \~chinese * @brief 对象状态 */ struct ObjectStatus { int code = 0; ///< 状态码,等于 0 时为成功状态,否则为失败状态 String msg; ///< 状态信息 /// \~chinese /// @brief 对象状态是否成功 inline bool Success() const { return this->code == 0; } /// \~chinese /// @brief 对象失败状态 static const int fail = -1; }; /** * \~chinese * @brief 对象失败状态异常 */ class ObjectFailException : public Exception { public: ObjectFailException(ObjectBase* obj, const ObjectStatus& status); /// \~chinese /// @brief 获取失败的对象指针 inline ObjectBase* GetObj() const { return obj_; } /// \~chinese /// @brief 获取对象状态 inline ObjectStatus GetStatus() const { return status_; } virtual char const* what() const override; private: ObjectBase* obj_; ObjectStatus status_; }; /** * \~chinese * @brief 对象处理策略方法 */ typedef Function ObjectPolicyFunc; /** * \~chinese * @brief 对象处理策略 */ struct ObjectPolicy { /// \~chinese /// @brief 忽略对象失败状态 static inline ObjectPolicyFunc Ignore() { return nullptr; } /// \~chinese /// @brief 在对象状态变为失败时打印警告日志 /// @param threshold 触发阈值 /// @return 对象处理策略方法 static ObjectPolicyFunc WarnLog(int threshold = ObjectStatus::fail); /// \~chinese /// @brief 在对象状态变为失败时打印错误日志 /// @param threshold 触发阈值 /// @return 对象处理策略方法 static ObjectPolicyFunc ErrorLog(int threshold = ObjectStatus::fail); /// \~chinese /// @brief 在对象状态变为失败时抛出 ObjectFailException(默认策略) /// @param threshold 触发阈值 /// @return 对象处理策略方法 static ObjectPolicyFunc Exception(int threshold = ObjectStatus::fail); }; /** * \~chinese * @brief 基础对象 */ class KGE_API ObjectBase : public RefObject , public Serializable { public: /// \~chinese /// @brief 构造基础对象 ObjectBase(); virtual ~ObjectBase(); /// \~chinese /// @brief 设置对象名 void SetName(const String& name); /// \~chinese /// @brief 获取对象名 String GetName() const; /// \~chinese /// @brief 判断对象的名称是否相同 /// @param name 需要判断的名称 bool IsName(const String& name) const; /// \~chinese /// @brief 获取用户数据 void* GetUserData() const; /// \~chinese /// @brief 设置用户数据 void SetUserData(void* data); /// \~chinese /// @brief 获取对象ID uint64_t GetObjectID() const; /// \~chinese /// @brief 序列化 void DoSerialize(Serializer* serializer) const override; /// \~chinese /// @brief 反序列化 void DoDeserialize(Deserializer* deserializer) override; /// \~chinese /// @brief 判断对象是否有效 virtual bool IsValid() const; /// \~chinese /// @brief 获取对象状态 ObjectStatus* GetStatus() const; /// \~chinese /// @brief 设置对象状态 void SetStatus(const ObjectStatus& status); /// \~chinese /// @brief 将对象标记为失败状态 void Fail(const String& msg, int code = ObjectStatus::fail); /// \~chinese /// @brief 清除对象状态 void ClearStatus(); /// \~chinese /// @brief 设置对象处理策略 static void SetObjectPolicy(const ObjectPolicyFunc& policy); public: /// \~chinese /// @brief 是否启用了内存泄漏追踪 static bool IsTracingLeaks(); /// \~chinese /// @brief 开始追踪内存泄漏 static void StartTracingLeaks(); /// \~chinese /// @brief 停止追踪内存泄漏 static void StopTracingLeaks(); /// \~chinese /// @brief 打印所有追踪中的对象信息 static void DumpTracingObjects(); /// \~chinese /// @brief 获取所有追踪中的对象 static Vector& GetTracingObjects(); private: static void AddObjectToTracingList(ObjectBase*); static void RemoveObjectFromTracingList(ObjectBase*); private: const uint64_t id_; bool tracing_leak_; String* name_; void* user_data_; ObjectStatus* status_; }; inline String ObjectBase::GetName() const { if (name_) return *name_; return String(); } inline bool ObjectBase::IsName(const String& name) const { return name_ ? (*name_ == name) : name.empty(); } inline uint64_t ObjectBase::GetObjectID() const { return id_; } } // namespace kiwano