/*
* Copyright 2018 The Android Open Source Project
*
* 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.
*/
#include "set_browsed_player.h"
namespace bluetooth {
namespace avrcp {
std::unique_ptr<SetBrowsedPlayerResponseBuilder>
SetBrowsedPlayerResponseBuilder::MakeBuilder(Status status,
uint16_t uid_counter,
uint32_t num_items_in_folder,
uint8_t folder_depth,
std::string folder_name) {
std::unique_ptr<SetBrowsedPlayerResponseBuilder> builder(
new SetBrowsedPlayerResponseBuilder(
status, uid_counter, num_items_in_folder, folder_depth, folder_name));
return builder;
}
size_t SetBrowsedPlayerResponseBuilder::size() const {
size_t len = BrowsePacket::kMinSize();
len += 1; // Status
// If the status isn't success the rest of the fields are ommited
if (status_ != Status::NO_ERROR) return len;
len += 2; // UID Counter
len += 4; // Number of items in folder
len += 2; // UTF-8 Character Set
len += 1; // Folder Depth
// This is only included if the folder returned isn't the root folder
if (folder_depth_ != 0) {
len += 2; // Folder Name Size;
len += folder_name_.size(); // Folder Name
}
return len;
}
bool SetBrowsedPlayerResponseBuilder::Serialize(
const std::shared_ptr<::bluetooth::Packet>& pkt) {
ReserveSpace(pkt, size());
BrowsePacketBuilder::PushHeader(pkt, size() - BrowsePacket::kMinSize());
AddPayloadOctets1(pkt, (uint8_t)status_);
if (status_ != Status::NO_ERROR) return true;
AddPayloadOctets2(pkt, base::ByteSwap(uid_counter_));
AddPayloadOctets4(pkt, base::ByteSwap(num_items_in_folder_));
AddPayloadOctets2(pkt, base::ByteSwap((uint16_t)0x006a)); // UTF-8
AddPayloadOctets1(pkt, folder_depth_);
// Skip adding the folder name if the folder depth is 0
if (folder_depth_ == 0) return true;
uint16_t folder_name_len = folder_name_.size();
AddPayloadOctets2(pkt, base::ByteSwap(folder_name_len));
for (auto it = folder_name_.begin(); it != folder_name_.end(); it++) {
AddPayloadOctets1(pkt, *it);
}
return true;
}
uint16_t SetBrowsedPlayerRequest::GetPlayerId() const {
auto it = begin() + BrowsePacket::kMinSize();
return base::ByteSwap(it.extract<uint16_t>());
}
bool SetBrowsedPlayerRequest::IsValid() const {
if (!BrowsePacket::IsValid()) return false;
return size() == kMinSize();
}
std::string SetBrowsedPlayerRequest::ToString() const {
std::stringstream ss;
ss << "SetBrowsedPlayerRequestPacket: " << std::endl;
ss << " └ PDU = " << GetPdu() << std::endl;
ss << " └ Length = " << GetLength() << std::endl;
ss << " └ Player ID = " << loghex(GetPlayerId()) << std::endl;
ss << std::endl;
return ss.str();
}
} // namespace avrcp
} // namespace bluetooth