Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2423)

Unified Diff: device/bluetooth/bluez/bluetooth_service_attribute_value_bluez.cc

Issue 2084463002: BlueZ + DBus implementations of create/remove service record functions. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fixes + moar tests Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: device/bluetooth/bluez/bluetooth_service_attribute_value_bluez.cc
diff --git a/device/bluetooth/bluez/bluetooth_service_attribute_value_bluez.cc b/device/bluetooth/bluez/bluetooth_service_attribute_value_bluez.cc
new file mode 100644
index 0000000000000000000000000000000000000000..2a6a71a7c97e0f7e6bbf3455f1a691dd7112bbd5
--- /dev/null
+++ b/device/bluetooth/bluez/bluetooth_service_attribute_value_bluez.cc
@@ -0,0 +1,60 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "device/bluetooth/bluez/bluetooth_service_attribute_value_bluez.h"
+
+#include <vector>
+
+#include "base/values.h"
+
+namespace bluez {
+
+BluetoothServiceAttributeValueBlueZ::BluetoothServiceAttributeValueBlueZ(
+ Type type,
+ size_t size,
+ base::Value* value)
+ : type_(type), size_(size) {
+ CHECK_NE(type, SEQUENCE);
+ value_.value = value;
+}
+
+BluetoothServiceAttributeValueBlueZ::BluetoothServiceAttributeValueBlueZ(
+ Type type,
+ size_t size,
+ Sequence* sequence)
+ : type_(type), size_(size) {
+ CHECK_EQ(type, SEQUENCE);
xiyuan 2016/06/22 15:53:05 Since SEQUENCE is the only allowed type, why not o
rkc 2016/06/22 21:06:36 Makes sense. Done.
+ CHECK_EQ(sequence->size(), size);
xiyuan 2016/06/22 15:53:05 Same here. It seems we can init |size_| with seque
rkc 2016/06/22 21:06:36 Done.
+ this->value_.sequence = sequence;
+}
+
+BluetoothServiceAttributeValueBlueZ::BluetoothServiceAttributeValueBlueZ(
+ const BluetoothServiceAttributeValueBlueZ& attribute) {
+ this->type_ = attribute.type_;
+ this->size_ = attribute.size_;
+
+ if (attribute.type_ != SEQUENCE) {
+ this->value_.value = attribute.value_.value->DeepCopy();
+ return;
+ }
+
+ this->value_.sequence =
+ new std::vector<BluetoothServiceAttributeValueBlueZ>();
+ for (const auto& v : *attribute.value_.sequence)
xiyuan 2016/06/22 15:53:05 Can we do: this->value_.sequence = new std::vec
rkc 2016/06/22 21:06:36 Done.
+ this->value_.sequence->push_back(v);
+}
+
+BluetoothServiceAttributeValueBlueZ::~BluetoothServiceAttributeValueBlueZ() {
+ // value_ is a union of two pointers, so we can check either.
+ if (!value_.value)
+ return;
+
+ if (type_ == SEQUENCE) {
+ delete value_.sequence;
+ } else {
+ delete value_.value;
+ }
+}
+
+} // namespace bluez

Powered by Google App Engine
This is Rietveld 408576698