/* * Copyright (c) 2024 Huawei Device Co., Ltd. * 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 META_INTERFACE_CONNECTOR_H #define META_INTERFACE_CONNECTOR_H #include #include #include #include #include #include META_BEGIN_NAMESPACE() /** * @brief Interface for objects that do event <-> meta function connections. * Such objects are usually attachments and so the actual connection is done when attaching to the destination * object. */ class IConnector : public CORE_NS::IInterface { META_INTERFACE(CORE_NS::IInterface, IConnector, "a6c9f964-da3e-45e1-8301-ca8c4ff1c628") public: /** * @brief Connect event to meta function. * @param source Object that contains the event. * @param event Name of the event. * @param func Name of the function, the attached object is used as destination object. * @return True on success, otherwise false. * Note: This doesn't do the actual connection, it is done when the attachement is added to an object. */ virtual bool Connect(const IObject::Ptr& source, const BASE_NS::string& event, const BASE_NS::string& func) = 0; /** * @brief Get the source object or null if not set (or alive). */ virtual IObject::Ptr GetSource() const = 0; /** * @brief Get the event name. */ virtual BASE_NS::string GetEventName() const = 0; /** * @brief Get the function name. */ virtual BASE_NS::string GetFunctionName() const = 0; }; META_END_NAMESPACE() #endif