1f857971dSopenharmony_ci/* 2f857971dSopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 3f857971dSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4f857971dSopenharmony_ci * you may not use this file except in compliance with the License. 5f857971dSopenharmony_ci * You may obtain a copy of the License at 6f857971dSopenharmony_ci * 7f857971dSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8f857971dSopenharmony_ci * 9f857971dSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10f857971dSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11f857971dSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12f857971dSopenharmony_ci * See the License for the specific language governing permissions and 13f857971dSopenharmony_ci * limitations under the License. 14f857971dSopenharmony_ci */ 15f857971dSopenharmony_ci 16f857971dSopenharmony_ci#ifndef DRAG_DATA_PACKER_H 17f857971dSopenharmony_ci#define DRAG_DATA_PACKER_H 18f857971dSopenharmony_ci 19f857971dSopenharmony_ci#include <map> 20f857971dSopenharmony_ci#include <string> 21f857971dSopenharmony_ci#include <vector> 22f857971dSopenharmony_ci 23f857971dSopenharmony_ci#include "parcel.h" 24f857971dSopenharmony_ci 25f857971dSopenharmony_ci#include "drag_data.h" 26f857971dSopenharmony_ci 27f857971dSopenharmony_cinamespace OHOS { 28f857971dSopenharmony_cinamespace Msdp { 29f857971dSopenharmony_cinamespace DeviceStatus { 30f857971dSopenharmony_ci 31f857971dSopenharmony_ciusing SummaryMap = std::map<std::string, int64_t>; 32f857971dSopenharmony_ciclass DragDataPacker { 33f857971dSopenharmony_cipublic: 34f857971dSopenharmony_ci static int32_t Marshalling(const DragData &dragData, Parcel &data, bool isCross = false); 35f857971dSopenharmony_ci static int32_t UnMarshalling(Parcel &data, DragData &dragData, bool isCross = false); 36f857971dSopenharmony_ci static int32_t CheckDragData(const DragData &dragData); 37f857971dSopenharmony_ci}; 38f857971dSopenharmony_ci 39f857971dSopenharmony_ciclass ShadowPacker { 40f857971dSopenharmony_cipublic: 41f857971dSopenharmony_ci static int32_t Marshalling(const std::vector<ShadowInfo> &shadowInfos, Parcel &data, bool isCross = false); 42f857971dSopenharmony_ci static int32_t UnMarshalling(Parcel &data, std::vector<ShadowInfo> &shadowInfos, bool isCross = false); 43f857971dSopenharmony_ci static int32_t PackUpShadowInfo(const ShadowInfo &shadowInfo, Parcel &data, bool isCross = false); 44f857971dSopenharmony_ci static int32_t UnPackShadowInfo(Parcel &data, ShadowInfo &shadowInfo, bool isCross = false); 45f857971dSopenharmony_ci static int32_t CheckShadowInfo(const ShadowInfo &shadowInfo); 46f857971dSopenharmony_ci}; 47f857971dSopenharmony_ci 48f857971dSopenharmony_ciclass SummaryPacker { 49f857971dSopenharmony_cipublic: 50f857971dSopenharmony_ci static int32_t Marshalling(const SummaryMap &val, Parcel &parcel); 51f857971dSopenharmony_ci static int32_t UnMarshalling(Parcel &parcel, SummaryMap &val); 52f857971dSopenharmony_ci}; 53f857971dSopenharmony_ci 54f857971dSopenharmony_ciclass ShadowOffsetPacker { 55f857971dSopenharmony_cipublic: 56f857971dSopenharmony_ci static int32_t Marshalling(const ShadowOffset &shadowOffset, Parcel &parcel); 57f857971dSopenharmony_ci static int32_t UnMarshalling(Parcel &parcel, ShadowOffset &shadowOffset); 58f857971dSopenharmony_ci}; 59f857971dSopenharmony_ci} // namespace DeviceStatus 60f857971dSopenharmony_ci} // namespace Msdp 61f857971dSopenharmony_ci} // namespace OHOS 62f857971dSopenharmony_ci#endif // DRAG_DATA_PACKER_H 63