/* * * Copyright (c) 2023 Project CHIP 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 #import #import /** * This file defines functions to resolve Matter cluster and attribute IDs into * strings. */ /** * Resolve Matter cluster IDs into a descriptive string. * * For unknown IDs, a string '' will be returned. */ MTR_EXTERN MTR_AVAILABLE(ios(17.6), macos(14.6), watchos(10.6), tvos(17.6)) NSString * MTRClusterNameForID(MTRClusterIDType clusterID); /** * Resolve Matter attribute IDs into a descriptive string. * * For unknown IDs, a string '' (if the cluster ID is not known) * or '' (if the cluster ID is known but the attribute ID is not known) * will be returned. */ MTR_EXTERN MTR_AVAILABLE(ios(17.6), macos(14.6), watchos(10.6), tvos(17.6)) NSString * MTRAttributeNameForID(MTRClusterIDType clusterID, MTRAttributeIDType attributeID); /** * Resolve Matter request (client to server) command IDs into a descriptive string. * * For unknown IDs, a string '' (if the cluster ID is not known) * or '' (if the cluster ID is known but the command ID is not known) * will be returned. */ MTR_EXTERN MTR_NEWLY_AVAILABLE NSString * MTRRequestCommandNameForID(MTRClusterIDType clusterID, MTRCommandIDType commandID); /** * Resolve Matter response (server to client) command IDs into a descriptive string. * * For unknown IDs, a string '' (if the cluster ID is not known) * or '' (if the cluster ID is known but the command ID is not known) * will be returned. */ MTR_EXTERN MTR_NEWLY_AVAILABLE NSString * MTRResponseCommandNameForID(MTRClusterIDType clusterID, MTRCommandIDType commandID); /** * Resolve Matter event IDs into a descriptive string. * * For unknown IDs, a string '' (if the cluster ID is not known) * or '' (if the cluster ID is known but the event ID is not known) * will be returned. */ MTR_EXTERN MTR_NEWLY_AVAILABLE NSString * MTREventNameForID(MTRClusterIDType clusterID, MTREventIDType eventID);